COMBOX



在传统页面的设计中,使用select标记作为下拉列表框,但在ExtJs中 ComboBox并不是一个select,不得不说ExtJs把按钮改的面目全非,这看起来和select标记别无二致,只是更加的漂亮了,再看看 ExtJs帮我生成的代码,会发现select扯不上任何关系了,取而代之的是N个div,复杂了N多,这便是美丽所付出的代价。

ComboBox组件却需要Ext.data来提供数据。于是Ext.data成了数据的来源,控件则负责显示数据。分工如此的明确,就像PHP中的MVC模式。

Ext.data中有三个比较复杂的类:DataProxy, DataReader, Store. 这三个类难以用语言来描述。暂时可以这么理解:
DataProxy : 获取的数据(可以是数组,Json格式,xml格式),来自本地或者远程。就像数据库中二维表的数据形式。
DataReader : 定义数据项的逻辑结构,数据的类型等。就像数据库中二维表的字段定义。
Store : 存储器,用于整合Proxy和Reader,相当于把两个东西整合起来。

Ext.data.DataProxy类并不常使用, 一般使用它的子类:
MemoryProxy : 获取内存数据,可以是数组、json、xml
HttpProxy : 使用HTTP协议通过ajax获取数据
ScriptTagProxy: 和HttpProxy类似,但支持跨域获取数据。

如下我们定义一个城市的数据Proxy

var cityProxy = new Ext . data . MemoryProxy ([
    
[ 1 , ' 福州市 ' ] ,
    
[ 2 , ' 厦门市 ' ] ,
    
[ 3 , ' 泉州市 ' ] ,
    
[ 4 , ' 漳州市 ' ] ,
    
[ 5 , ' 三明市 ' ]
]) ;

Ext.data.DataReader类,其实总是依靠DataProxy做事,主要定义Proxy的逻辑结构,如:逻辑名称:name,数据类型:type,列与数据源的索引映射:mapping等等
data.DataReader类也有三个子类:Ext.data.ArrayReader、Ext.data.JsonReader、Ext.data.XmlReader
由于上面建立的数组形式的cityProxy,那么建立逻辑结果也需要使用ArrayReader

var cityReader = new Ext . data . ArrayReader ({} , [
    
{ name : ' cid ' , type : ' int ' , mapping : 0 } ,
    
{ name : ' cname ' , type : ' string ' , mapping : 1 }
]) ;

接下来的Store就简单了

var cityStore = new Ext . data . Store ({
    
proxy : cityProxy ,
    
reader : cityReader ,
    
autoLoad : true //开启自动加载,一般情况下没有开启,属于延迟加载,也可以采用 cityStore.load()方法
}) ;

我们用画张图来看看关系:

可以看出Ext.data.Store的主要目的是在内存中建立一张数据表,在填充到形态千差万别的组件中,如:ComboBox和GridPanel。
建立一个典型的下拉框:

var cityCombo = new Ext . form . ComboBox ({
    
renderTo : Ext . getBody () ,
    
hiddenName   : ' city ' , //在ComboBox,中hiddenName才是真正的名字
    
mode   : ' local ' ,    //默认是remote远程获取模式
    
triggerAction : ' all ' ,
    
store : cityStore ,    //选择我们刚刚的数据源
    
displayField : ' cname ' //显示的字段
    
valueField   : ' cid ' ,    //真实的字段
    
emptyText    : ' 请选择福建的城市 ' ,
}) ;

再设置一个按钮通过ComboBox类中的两个方法:getValue()和getRawValue(),来查看下拉列表框的显示值和真实值:

var btn = new Ext . Button ({
    
text : ' 列表框的值 ' ,
    
renderTo : Ext . getBody () ,
    
handler : function () {
        
Ext . Msg . alert ( ' 结构 ' , ' 实际值: ' + cityCombo . getValue () + ' ; 显示值: ' + cityCombo . getRawValue ()) ;
    
}
}) ;
特点1:美化的并且可自定义的外观 该下拉框使用JS进行渲染。下拉框样式如下: 该外观是由CSS和图片控制。通过修改CSS可以很方便地实现更改外观。 QUI树形下拉框不存在IE6中无法被浮动层遮住等问题。 特点2:使用简单 引入脚本和相应的CSS之后, 在页面写如下的HTML代码: 然后为其指定JSON数据即可。数据格式: var zNodes1 =[ { id:1, pId:0, name:"父节点1",open:true}, { id:11, pId:1, name:"叶子节点11"}, { id:12, pId:1, name:"叶子节点12"}, { id:13, pId:1, name:"叶子节点13"}, { id:2, pId:0, name:"父节点2 ",open:true}, { id:211, pId:2, name:"叶子节点21"}, { id:212, pId:2, name:"叶子节点22"}, { id:213, pId:2, name:"叶子节点23"}, { id:214, pId:2, name:"叶子节点24"} ]; 特点3:控制某些节点不可选 如果希望某些子节点(例如父节点)不可选择,为该项JSON数据设置clickExpand:true即可,这样点击后不会选中项,而是展开子节点。 特点4:触发close事件 可以为selectTree的div添加close事件,每当内容层关闭时会调用。通过这种方式可以将选中项传递给hidden表单元素,用于提交表单。 特点5:自定义图标 下拉框树结构每个节点都可以自定义图标。效果如下: 特点6:宽度处理 QUI树形下拉框对于宽度的处理方式是:默认会有一个宽度,当树结构过宽则内容层会增大宽度用于自适应里面的内容。 还可以为下拉框和内容层强制指定一个宽度。效果如下: 特点7:树形下拉框可编辑 为下拉框代码添加一个editable="true"属性,就把它变成了一个可编辑的下拉框,效果如下: 特点8:可通过AJAX方式加载数据 下拉框的树结构可以通过ajax方式加载。详情请参见在线相关示例。 特点9:变成树形多选下拉框 为下拉框添加multiMode="true"属性,可以把它变成树形多选下拉框。效果如下: 当选择完毕后,鼠标移入可以显示所有选择的选项提示。效果如下: 特点10:树形多选下拉框的不分组模式 改变树形多选下拉框的JSON数据,让其不分组。那么就变成一个select多选下拉框。效果如下: 特点11:树形下拉框的验证 结合QUI框架的验证机制,可以方便地为树形下拉框添加验证。效果如下: 特点12:树形下拉框动态增删改选项 树形下拉框支持动态增删改选项。结合ajax机制可以方便地实现如下效果: 添加一个节点后的效果: 特点13:完美的浏览器兼容性 无论是IE6、IE7、IE8、IE9还是FireFox、Chrome、Safira,甚至在Linux下都保持功能与外观的一致性。 声明:本组件内部的树结构采用的是zTree组件,感谢zTree组件作者的支持与授权。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值