Webappbuilder自定义widget模板

Webappbuilder自定义widget模板

by 李远祥

  1. 到\\widgets\samplewidgets目录下拷贝 CustomWidgetTemplate 文件并重命名为MyWidget

  2. 设置widget的类名。在MyWidget 目录下打开Widget.js ,将baseClass 改为

    baseClass: ‘jimu-widget-mywidget‘ 如下图

  1. 自定义widget的UI界面。在Widget.html 文件中可以添加其widget的界面。可以尝试将以下代码加入到这个html页面中。

  2. 将自定义的widget注册到应用中。打开stemapp/sample-configs 文件,找到widgetPool->widgets ,添加一个节点内容,然后保存文件

  3. 测试widget 。 打开 http://[your host name:3344]/webappviewer/?config=sample-configs/config-demo.json  点击图标,出现其图标,操作结果如下

  4. 让widget变得更加灵活可配

    a.打开MyWidget  文件夹下的 config.json 文件,添加json的结构文本到查建中,如下

    b. 将原来的widget.html 页面代码改为,让其可以直接读取配置的关键变量

    c.打开第5步的测试连接,查看修改的内容。Widget的内容则变为config文件对应的变量。

  5. 让界面更加友好一些。一般来说,html的界面布局和美化都使用css文件,widget同样可以使用CSS文件来让整个界面变得比较美观。打开css/style.css 文件,增加css代码到该文件中,如下图所示:

    该代码的作用是将页面的第一个div标签的内容设置为红色。这样做的好处是更好的结构化,让美工人员参与到应用程序的开发过程中。其最终的效果如下

  6. 访问地图
    1. 打开widget.js文件,删除startup函数的注释

    2. 修改widget.html的页面代码,加入map ID 属性,如下图

    3. 重新刷新页面,可以看到map空间的ID被现实出来
    4. 最终的结果是读取了应用中map控件的ID

  7. 国际化支持

    可以通过编写配置文件去适配多国语言。例如前面所用到的插件是英文的提示"This is my widget" and "This is configurable" ,可以通过编写MyWidget文件夹的配置文件去实现中文本地化。

    1. 打开nls/strings.js 文件,增加以下代码

    2. 在nls目录下创建子文件夹 zh-cn ,如图所示

    3. 将string.js 拷贝到zh-cn文件夹中
    4. 修改zh-cn/strings.js 文件里面的内容,如下

    5. 将widget.html的内容修改为读取配置代码,如下图

    6. 重新刷新页面即可查看到中文的配置。效果如下图

  8. 部署widget
    1. 打开MyWidget文件夹里面的 manifest.json 文件,更改里面的属性,如name、author、description等,其中name属性必须与widget的文件夹名称相同。

      具体的每个属性可以查看网址 https://developers.arcgis.com/web-appbuilder/guide/widget-manifest.htm 的说明。

    2. 将MyWidget 文件夹拷贝到\stemapp\widgets 文件夹下,启动node.js(最快的港式是直接打开webappbuilider文件夹下的start.bat文件),输入http://[your host name:3344]/webappbuilder,这样在使用webappbuilder创建应用的时候就可以使用自定义的widget了。如下图在微件选择的时候就会出现定义的插件

时间: 2024-10-12 13:42:15

Webappbuilder自定义widget模板的相关文章

android自定义UI模板图文详解

不知道大家在实际开发中有没有自定义过UI模板?今天花时间研究了一下android中自定义UI模板,与大家分享一下. 每个设计良好的App都是自定义标题栏,在自定义标题栏的过程中大部分人可能都是自定义一个标题的xml文件,然后在需要的地方直接通过include来引用,这比起在每个布局文件中写标题栏已经进化很多了,但仍然不是最简单有效的方法,我们为什么不能自定义一个标题控件呢?今天就带大家自己做一个标题栏控件.效果图如下: 开始啦: 第一步:自定义xml属性 新建一个android项目,在value

arcgis viewer for flex 之 自定义widget(arcmap设计pie圆饼图)

自定义Widget 终于可以实现第一个Widget了,按照惯例,我们通过一个Hello World Widget来说明如何在Flex Viewer中开发.编译.配臵.部署和使用自定义Widget.Flex Viewer的源代码中已经包含了一个HelloWorld Widget,我们还是亲手尝试一下吧. 1) 安装Flash Builder,下载Flex Viewer源码,我们使用最新的2.3: 2) 打开Flash Builder,导入Flex Viewer 2.3的源代码: 3) 鼠标放在wi

自定义 Yasnippet 模板

yasnippet可以把我们常用的代码段或文本储存起来,到使用的时候只需键入几个字母就会自动带出. 比如我们在写python代码时,常常会在文件的第一行写下: #!/usr/bin/env python,经常这么手工键入是不是很没有效率,用yasnippet来帮你! 方法: 一.新建snippet 使用命令 M-x yas-new-snippet 打开一个新buffer,或者直接新建一个文件,输入内容后保存到你指定的位置即可. 用M-x yas-new-snippet 打开的buffer内容默认

MyEclipse自定义servlet模板

每次用MyEclipse默认的servlet的模板创建servlet的时候,里面会生成好多没有用的代码.因此,我们可以自定义servlet模板.步骤如下: 找到com.genuitec.eclipse.wizards_11.5.0.me201310291746.jar 文件,该文件在MyEclipse(本人安装的是MyEclipse Professional 2014)安装目录下的/plugins下 打开com.genuitec.eclipse.wizards_11.5.0.me20131029

前端编辑器-自定义html模板

1.webstorm 自定义html模板 我们需要找到设置创建模板的地方,步骤如下: File  ->  settings ->  Editor  ->  File and Code Templates 找到这个位置,我们就会看见这个界面,在导航栏的右侧部分的左上角有个+号我们就可以开始创建模板了, 如上图所示,Name所对应的地方是用来写HTML模板的名字, 这会方便我们选择的是哪一个模板, Extension是我们我们的模板是什么类型的文档,此地理所应当是填html, 空白区域是放h

Android Studio自定义注释模板

博主是从Eclipse转来Android Studio 的,总体来说,Android Studio是比Eclipse优秀和智能许多.但是对于我们这些用习惯了Eclipse的开发者来说,或多或少还是一些不适应的地方.快捷键什么的额.但是,今天我们不是要说快捷键,我们要说一说自定义注释模板.用过Eclipse的开发者应该都喜欢在文件的头部或者其他地方加上一些我们自己的信息,当然,这些信息都是我们自定义编辑进去的.那么,转到Android Studio后,我们还能不能自定义注释模板呢?答案是肯定的.下

ThinkPHP框架配置自定义的模板变量(十)

原文:ThinkPHP框架配置自定义的模板变量(十) 模板替换(手册有详细介绍对应的目录) __PUBLIC__:会被替换成当前网站的公共目录 通常是 /Public/ __ROOT__: 会替换成当前网站的地址(不含域名) __APP__: 会替换成当前项目的URL地址 (不含域名) __GROUP__:会替换成当前分组的URL地址 (不含域名) __URL__: 会替换成当前模块的URL地址(不含域名) __ACTION__:会替换成当前操作的URL地址 (不含域名) __SELF__: 会

xml布局自定义SurfaceView模板

package com.dream.apm; import android.content.Context; import android.graphics.Canvas; import android.graphics.Color; import android.graphics.Paint; import android.graphics.RectF; import android.util.AttributeSet; import android.util.Log; import andr

PHP 自定义 Smarty 模板引擎类 高洛峰 细说PHP

smarty模板引擎类简单工作原理 利用Smarty 模板引擎类对模板文件中的变量进行编译,编译过程其实就是利用正则表达式翻译成PHP文件.例如 模板文件中{$title} 利用正则表达式找到并替换成  <?php echo $this->vars['title'];?> 自定义 Smarty 模板引擎类 smarty.class.php页面 <?php /*  * 自定义Smarty模板引擎类  */         class Smarty{             priva