这里给联动进行一个简单定义:因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. Codeforces Round #417 B. Sagheer, the Hausmeister

    B. Sagheer, the Hausmeister time limit per test  1 second memory limit per test  256 megabytes   Som ...

  2. Nuget Tips

    Install-Package时老是提示找不到Available Source,研究了下Nuget Package Manager的配置.发现有两个地方可以改: 1.Visual Studio中Too ...

  3. Visual Studio 与 Visual C++ 关系

      Visual Studio .net Visual C++ .net Visual C++ _MSC_VER 备注 Visual Studio .net 2002 Visual C++ .net ...

  4. MUI框架-09-MUI 与后台数据交互

    MUI框架-09-MUI 与后台数据交互 本篇介绍使用 art-template 和原生 MUI 的数据交互 mui.ajax 来实现 我们大家都知道,想要数据交互就要有数据,每次当我们发送请求,我们 ...

  5. linux 加jre环境变量

    1.vi /etc/profile 2.未行添加 export JAVA_HOME=/usr/local/java export CLASSPATH=.:$JAVA_HOME/lib/tools.ja ...

  6. maven(15),快照与发布,RELEASE与SNAPSHOT

     发布RELEASE 用户A将代码打包发布到RELEASE仓库,具体操作参考上篇文章.用户B使用时,需要在pom.xml添加JAR包的依赖坐标.如果用户A将版本从1.0升级为2.0,用户B使用时也 ...

  7. HTML5盒子模型。

    盒子模型. 盒子由 margin.border.padding.content 四部分组成. margin :外边距 border:边框 padding:内边距 (内容与边框的距离) content: ...

  8. Oracle - ORA-28547: Connection to server failed,probable Oracle Net admin error (Navicat)

    一.异常 用Navicat连接Oracle数据库时抛出的异常 二.方案 使用 Oracle 安装目录 \Oracle\product\11.2.0\dbhome_1\BIN 下的 oci.dll 替换 ...

  9. CAShapeLayer的使用[2]

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

  10. django定义Model中的方法和属性

    #定义一个Model class UserProfile(models.Model): user=models.OneToOneField(User,unique=True) phone=models ...