这里给联动进行一个简单定义:因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. JavaScript 小实例 - 表单输入内容检测,对页面的增删改

    JavaScript 小实例 - 表单输入内容检测,对页面的增删改 效果体验地址:https://xpwi.github.io/js/JavaScript01/jsForm.html 功能: 1.向页 ...

  2. 安卓app开发-05-Android xml布局详细介绍

    安卓app开发-05-Android xml布局详细介绍 虽然说有 墨刀,墨客 这些图形化开发工具来做 Android 的界面设计,但是我们还是离不开要去学习做安卓原生app,学习 xml 布局还是必 ...

  3. select 时进行update的操作,在高并发下引起死锁

    场景:当用户查看帖子详情时,把帖子的阅读量:ReadCount+1 select title,content,readcount from post where id='xxxx'   --根据主键查 ...

  4. c# webservice中访问http和https的wsdl,生成的配置节点的不同之处

    http: https:

  5. 获取当前网页的的url

    如果测试的url地址是http://www.test.com/testweb/default.aspx, 结果如下: Request.ApplicationPath:                / ...

  6. CentOS 6 各种启动文件损坏及修复

    stage1 mbr的破坏和恢复 清空mbr 前446字节 dd if=/dev/zero of=/dev/sda bs=1 count=446 如果没有挂载启动光盘,会显示这样 如果启动前挂载了光盘 ...

  7. Linux命令--网络管理

    write命令 Linux write命令用于传讯息给其他使用者. 使用权限:所有使用者. 语法 write user [ttyname] 参数说明: user : 预备传讯息的使用者帐号 ttyna ...

  8. JSON与对象的序列化与反序列化

    一.利用JavaScriptSerializer 类 System.Web.Script.Serialization空间,位于System.Web.extensions.dll中. JavaScrip ...

  9. Tomcat是如何将请求一步步传递到我们编写的HttpServlet类中的

    我们平常编写好的HttpServlet类后,就可以处理请求了,但是服务器在接收到请求信息以后是如何将这些请求传递到我们编写的Servlet类中的???这个疑问在我心中的已经很久了,现在要来解决它. 我 ...

  10. 在windows下解压缩rar文件

    这是一篇比较无聊的博文.只是给博客除草的. 我从我的移动硬盘里翻出来了一堆电子书,从哪拿到的我忘了,但是都打在rar的压缩包里,这让我查找起来非常不方便.前几天找某本书看,就没有查到,又百度到的下载地 ...