这里给联动进行一个简单定义:因Combobox选择或输入的值发生改变时对自身或者其它组件产生影响称为联动。(注:editable确定是否可以手动输入)

有两种实现方法:

一、自己写对应的onChange、onSelect方法进行联动。这种方法灵活性强一些。

注意这两个方法的激发条件即可,尤其注意在数据赋值而激发的负面影响,会导致loadData事件失效。

详细可参考JQuery/EasyUI内的文档,较为全面。

二、调用框架内部内置的方法

以地区四级联动为例

 <fieldset>
<legend>地址选择</legend>
</fieldset>
<div class="topjui-row">
<div class="topjui-col-sm6">
<label class="topjui-form-label">省</label>
<div class="topjui-input-block">
        <input type="text" id="province" name="province" data-toggle="topjui-combobox"
        data-options="valueField:'text',url:contextPath + '/common/_address.jsp?areaName=-1',
childCombobox:{ id:'city', url:contextPath + '/common/_address.jsp?areaName={parentValue}'}">
</div>
</div>
<div class="topjui-col-sm6">
<label class="topjui-form-label">市</label>
<div class="topjui-input-block">
        <input type="text" id="city" name="city" data-toggle="topjui-combobox"
        data-options="valueField:'text',
        childCombobox:{ id:'county', url:contextPath + '/common/_address.jsp?areaName={parentValue}'}">
</div>
</div>
</div>
<div class="topjui-row">
<div class="topjui-col-sm6">
<label class="topjui-form-label">县/区</label>
<div class="topjui-input-block">
        <input type="text" id="county" name="county" data-toggle="topjui-combobox" data-options="valueField:'text'">
</div>
</div>
<div class="topjui-col-sm6">
<label class="topjui-form-label">地址</label>
<div class="topjui-input-block">
        <input type="text" id="street" name="street" data-toggle="topjui-textbox"
        data-options="validType:'length[0,50]'">
</div>
</div>
</div>

childCombobox在onChange中激活,即值发生改变后会同步联动其相关联的组件,代码如下:

 if ("object" == typeof d.childCombobox) {
var e = d.childCombobox,
f = a("#" + e.id);
if (f.combobox("setText", ""), f.combobox("setValue", ""), e.url) {
var g = e.url.replace("{parentValue}", b);
f.combobox("reload", g)
}
}

可以在此添加与其它组件间的联动,如添加对文本框的联动

 if ("object" == typeof d.childTextbox) {
var e = d.childTextbox,
f = a("#" + e.id);
if (f.textbox("setText", ""), f.textbox("setValue", ""), e.url) {
var g = e.url.replace("{parentValue}", b);
$.getJSON(g, function (da) {
f.textbox("setValue", da.text);
f.textbox("setText", da.text);
});
}
}

附:全国行政三级地区数据下载地址(四级过大)

CREATE TABLE `s_area` (
`areaId` int(20) NOT NULL COMMENT 'ID',
`areaCode` varchar(50) NOT NULL COMMENT ' 地区码',
`areaName` varchar(30) NOT NULL COMMENT '地区名称',
`level` tinyint(4) DEFAULT '-1' COMMENT '级别',
`cityCode` varchar(50) DEFAULT NULL COMMENT '电话区号',
`center` varchar(50) DEFAULT NULL COMMENT '经纬度',
`parentId` int(20) NOT NULL,
`zipCode` varchar(6) NOT NULL DEFAULT '' COMMENT '邮编',
`fullName` varchar(50) NOT NULL DEFAULT '' COMMENT '地址全称',
PRIMARY KEY (`areaId`,`parentId`,`areaName`),
KEY `areaCode` (`areaCode`),
KEY `parentId` (`parentId`),
KEY `level` (`level`),
KEY `areaName` (`areaName`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='地区码表';
链接:https://pan.baidu.com/s/1gSnjtc1Yq1KovUB-j63KUw
提取码:mhdl

TopJUI Combobox 联动的更多相关文章

  1. vs2013+MVC3.0+EasyUI的ComboBox联动使用(二)

     vs2013+MVC3.0+EasyUI的ComboBox联动使用(二) 简单介绍:在vs2013(.net4.0)中使用MVC3.0对于EasyUI中ComboBox的联动使用. 载入Comb ...

  2. Extjs4 Combobox 联动始终出现loading错误的解决的方法

    当反复选者combobox 联动时,下级的Combobox 会出现loading的错误表现形式,尽管Store数据已载入完也是一样. 废话少说贴代码就知道怎样处理了:(注意红色部分的关键语句) }, ...

  3. Ext 4.2以后版本 ComboBox 联动

    //combox树 ComboTree: function (upDep, empStore) { var com = Ext.create('Ext.ux.desktop.ComboTree', { ...

  4. C# Combobox联动

    接上一篇博文,对界面做一个小修改,做4个combobox,形成窗口之间的联动: 界面如下: 选择combobox里的条件,单击查询获取数据 首先连接数据库,获取到数据到第一个combobox里,代码在 ...

  5. Extjs之combobox联动

    Ext.Loader.setConfig({ enabled : true }); Ext.Loader.setPath('Ext.ux', '../extjs/ux'); Ext.require([ ...

  6. TopJUI Combobox onSelect 事件失效BUG

    版本:2.2.8 onChange : function(b, c) 两个参数:当前选择后在Combobox中显示的数据,实际是textField:另一个是改变前的数据 onSelect : func ...

  7. ComboBox联动 (AJAX BS实现)

    //从webservice中取数据ajax            Ext.Ajax.request({                url: 'WebService.asmx/GetComboxFi ...

  8. MaterialDesign Or ComboBox 联动查询

    <ComboBox Width="200" Height="30" x:Name="ComboxName" Text="{B ...

  9. Extjs学习笔记(-):ComboBox联动

    http://www.cnblogs.com/wumin97136/archive/2007/12/24/1012720.html http://examples.ext.net/ http://ex ...

随机推荐

  1. CentOS6.5(3)----设置自己安装的程序开机自动启动

    CentOS6.5系统下设置自己安装的程序开机自动启动 方法1. 把启动程序的命令添加到 /etc/rc.d/rc.local 文件中,比如设置开机启动 mysqld: #!/bin/sh # # T ...

  2. 图片(imageView)

    图片(imageView): 常用属性: android:scaleType(图片显示的格式) android:src(图片源,一般使用的资源) android:scaleType属性的常用取值 0. ...

  3. MySQL 常用语句大全

    MySQL 常用语句大全 一.连接 MySQL 格式: mysql -h 主机地址 -u 用户名 -p 用户密码 1.例 1:连接到本机上的 MYSQL. 首先在打开 DOS 窗口,然后进入目录 my ...

  4. weex常用属性梳理

    之前发了一篇weex集成和开发的博客,主要是讲了weex开发环境的搭建和文件的编译.部署,还有就是一些个人对weex的理解,最近将原生的项目改造成weex的项目,也持续了有两个多月的时间了,后面我会发 ...

  5. Android根据URL下载文件保存到SD卡

    //下载具体操作 private void download() { try { URL url = new URL(downloadUrl); //打开连接 URLConnection conn = ...

  6. Intel酷睿前世今生(一)

    Intel酷睿系列自诞生起就树立了桌面CPU霸主的地位,酷睿i系列更是无人能敌.它是Intel阻击AMD多核构架的救赎主,也是AMD复兴梦想的收割者.而Intel酷睿系列已经经历几代了,不知还有多少看 ...

  7. CAShapeLayer的使用[2]

    CAShapeLayer的使用[2] CAShapeLayer支持的动画类型有如下这些. ------------------------------------------------------- ...

  8. Effective C++(10) 重载赋值操作符时,返回该对象的引用(retrun *this)

    问题聚焦: 这个准则比较简短,但是往往就是这种细节的地方,可以提高你的代码质量. 细节决定成败,让我们一起学习这条重载赋值操作符时需要遵守的准则吧. 还是以一个例子开始: Demo // 连锁赋值 x ...

  9. SQL查询含有%号的字段

    select * from EMS_ANNOUNCEMENT where 1=1  and title like '%\%%'  escape '\'

  10. 深入浅出SharePoint2007——定制搜索之无代码篇

    需求: 输入值,如果多行文本列包含此搜索关键字,显示对应的查询结果. 解决方案: 使用Form Web Part和Data form web part. 1 创建list,并创建3列 选中默认的lis ...