Ext 三级联动 及附值
/// <reference path="../../ext.js" />
Ext.define('Myview.Region', {
extend: 'Ext.form.FieldContainer',
alias: 'widget.fieldRegioncontainer',
layout: "hbox",
initComponent: function () {
var me = this;
//要点,附值时要设置SelectCity,SelectArea,Province控件的值
//由于附值时,直接设置City和Area时,相应的store加载后会把设置的值清空,所以只能加载完 store后从SelectCity,SelectArea获取初使的值
//省store
me.provinceStore = Ext.create("Ext.data.Store", {
autoLoad: true,
autoSync: false,
fields: [
{ name: "RegionId", type: "int" },
{ name: "RegionName" }
],
proxy: {
type: 'ajax',
url: "../sys/AjaxRegionService.aspx?method=GetArea",
reader: {
type: "json",
root: "data"
}
}
});
//市store
me.cityStore = Ext.create("Ext.data.Store", {
autoSync: false,
fields: [
{ name: "RegionId", type: "int" },
{ name: "RegionName" }
],
proxy: {
type: 'ajax',
url: "../sys/AjaxRegionService.aspx?method=GetArea",
reader: {
type: "json",
root: "data"
}
},
listeners: {
load: function () {
var selectCity = Ext.getCmp('SelectCity').getValue();
if (selectCity != null && selectCity.length > 0) {
var index = me.cityStore.find("RegionId", parseInt(selectCity));
if (index >= 0) {
Ext.getCmp('City').setValue(parseInt(selectCity));
}
}
}
}
}
);
//县store
me.areaStore = Ext.create("Ext.data.Store", {
autoSync: false,
fields: [
{ name: "RegionId", type: "int" },
{ name: "RegionName" }
],
proxy: {
type: 'ajax',
url: "../sys/AjaxRegionService.aspx?method=GetArea",
reader: {
type: "json",
root: "data"
}
},
listeners: {
load: function () {
var selectCity = Ext.getCmp('SelectArea').getValue();
if (selectCity != null && selectCity.length > 0) {
var index = me.areaStore.find("RegionId", parseInt(selectCity));
if (index >= 0) {
Ext.getCmp('Area').setValue(parseInt(selectCity));
}
}
}
}
});
//省
me.province = Ext.create('Ext.form.ComboBox', {
allowBlank: false, flex: 1,
queryMode: "local", id:"Province",
name: "Province", valueField: "RegionId", displayField: "RegionName", store: me.provinceStore,
listeners: {
change: function (f, n, o) {
var p = this.store,
c = me.cityStore,
cb = this.up("form").getForm().findField("City"),
cb1 = this.up("form").getForm().findField("Area");
if (n && n != o) {
cb.setValue();
cb1.setValue();
c.getProxy().extraParams.parentid = n;
c.load();
}
}
}
});
//市
me.city = Ext.create('Ext.form.ComboBox', {
allowBlank: false, flex: 1,
queryMode: "local", id:'City',
name: "City", valueField: "RegionId", displayField: "RegionName", store: me.cityStore,
listeners: {
change: function (f, n, o) {
var p = this.store,
c = me.areaStore,
cb = this.up("form").getForm().findField("Area");
if (n && n != o) {
cb.setValue();
c.getProxy().extraParams.parentid = n;
c.load();
}
}
}
});
//县
me.area = Ext.create('Ext.form.ComboBox', {
allowBlank: false, flex: 1,
queryMode: "local", id:"Area",
name: "Area", valueField: "RegionId", displayField: "RegionName", store: me.areaStore,
});
me.items = [me.province, me.city, me.area, { xtype: 'hiddenfield', name: 'SelectCity', id: 'SelectCity' },
{ xtype: 'hiddenfield', name: 'SelectArea', id: 'SelectArea' }];
me.callParent(arguments);
}
});
Ext 三级联动 及附值的更多相关文章
- js封装的三级联动菜单(使用时只需要一行js代码)
前言 在实际的项目开发中,我们经常需要三级联动,比如省市区的选择,商品的三级分类的选择等等. 而网上却找不到一个代码完整.功能强大.使用简单的三级联动菜单,大都只是简单的讲了一下实现思路. 下面就给大 ...
- 利用select实现年月日三级联动的日期选择效果
× 目录 [1]演示 [2]规划 [3]结构生成[4]算法处理 前面的话 关于select控件,可能年月日三级联动的日期选择效果是最常见的应用了.本文是选择框脚本的实践,下面将对日期选择效果进行详细介 ...
- jQuery省市区三级联动插件
体验效果:http://hovertree.com/texiao/bootstrap/4/支持PC和手机移动端. 手机扫描二维码体验效果: 代码如下: <!DOCTYPE html> &l ...
- jQuery - 全国省市县三级联动
最近有空用jquery做了一个全国省市县的三级联动,在以后或许可以用的到 ,遗憾的是我还没用封装,等有空看能不能封装成一个插件 废话不多说,贴上代码: <!doctype html> &l ...
- 省市区三级联动 pickerView
效果图 概述 关于 省市区 三级联动的 pickerView,我想大多数的 iOS 开发者应该都遇到过这样的需求.在遇到这样的需求的时候,大多数人都会觉的这个很复杂,一时无从下手.其实真的没那么复杂. ...
- webForm(三)——三级联动
三级联动 首先附图一张,初步认识一下什么是三级联动: 注:选第一个后面两个变,选第二个,最后一个改变. 其次,做三级联动需要注意的方面:①DropD ...
- C#三级联动
1.运用ComboBox的控件建立效果,如右图: 2.建立三个表,第一个Province表: PID,PName;第二个为city表: CId,CName,PId;第三个为coun表:CounID,C ...
- JS省市区三级联动
不需要访问后台服务器端,不使用Ajax,无刷新,纯JS实现的省市区三级联动. 当省市区数据变动是只需调正js即可. 使用方法: <!DOCTYPE html><html>< ...
- easyUI下拉列表三级联动
首先是先想好数据库的搭建,通过地区id,地区名称,上级地区id就可以实现,所有省市区的数据 例如: DAO层 service层 Servlet 页面 <!DOCTYPE html> < ...
随机推荐
- SQLALchemy(连表)、paramiko
本节内容:
- mvn打包时添加version和profile
<!-- 定义profile --> <profiles> <!-- 开发环境 --> <profile> <id>dev</id&g ...
- js获取url的常用方法
//设置或获取对象指定的文件名或路径. console.log(window.location.pathname) //设置或获取整个 URL 为字符串. console.log(window.loc ...
- import pysam 出错解决办法
安装pysam后,import之,结果,出现报错: Library not loaded: libcurl.4.dylib 尝试很多办法,最终发现应当这样解决: # 首先重装curl brew ins ...
- 当padding,margin,top为百分比值,具体数值如何计算
padding以及margin的四个方向设置值为百分数的时候,是以父元素的宽度为基数来进行计算. (为了保持横向和纵向方向上的margin/padding一致,但是其实也不是一定以父元素的宽度为参照物 ...
- Surprise团队第三周项目总结
Surprise团队第二周项目总结 项目进展 这周我们小组的项目在上周的基础上进行了补充,主要注重在注册登录界面的实现,以及关于数据库的一些学习. 在设计注册登录界面时,每一块的地方控件都不一样,比如 ...
- imooc-java-作业练习-20150918
小伙伴们,请根据所学知识,编写一个 JAVA 程序,实现输出考试成绩的前三名 要求: 1. 考试成绩已保存在数组 scores 中,数组元素依次为 89 , -23 , 64 , 91 , 119 , ...
- 强制span不换行
对于上一篇提到的overflow的问题我好像搞懂一些了.事情大概是这个样子的:如果用了float属性,那么元素就会脱离文本的束缚,无法无天起来,这肯定是猿类无法忍受的.要想让他们乖乖就范,要么用清除浮 ...
- Linux-Rsync服务器/客户端搭建实战
一.需求 每晚汇总各机器的操作日志,同步到主服务器进行日志分析. 二.基础知识 rsync 分为服务器端.客户端,服务器端搭建比客户端辛苦一些(也是很简单). rsync 服务器是指以 deamon ...
- centos安装mongodb 3.2.9
centos 6.5 x64 1.下载地址:用迅雷下载,直接下载下不动 https://fastdl.mongodb.org/linux/mongodb-linux-x86_64-rhel62-3.2 ...