在开发中遇到两种情况:第一在新增窗体时,要动态加载CheckBox项;第二在修改时不但需要加载所有CheckBox项,还要并且选中之前新增时的选项

如图这是在修改页面的效果:

1.在新增窗体中动态加载checkboxgroup

1.1在新增窗体代码片段:

   {
xtype: 'panel',
width: 750,
border: false,
flex: 2,
items: [{
xtype: 'checkboxgroup',
id: 'lblOperationBehavior',
name: 'lblOperationBehavior',
itemCls: 'x-check-group-alt',
columns: 4,
fieldLabel: '设定权限',
labelWidth: 100,
width: 750,
align: 'left',
border: true,
anchor: '100%', flex: 1,
listeners: {
render: function (view, opt) {
LoadingOperationBehavior();
}
}
}]
},

1.2方法LoadingOperationBehavior()

//加载操作全部名称
function LoadingOperationBehavior() {
//通过extjs的ajax获取操作全部名称
Ext.Ajax.request({
url: '/ProjectWeb/HttpHandlerData/MemberManagement/MemberManagement.ashx?operation=SearchOperationBehavior',
success: function (response) {
var obj = eval("(" + response.responseText + ")");
var len = obj.data.length;//obj.data.length; "Table"这里的Table指的是后台返回 类似于data
if (obj.data == null || len == 0) {
return;
} var checkboxgroup = Ext.getCmp("lblOperationBehavior");
for (var i = 0; i < len; i++) {
var checkbox = new Ext.form.Checkbox(
{
boxLabel: obj.data[i].OperationName,//obj.Table[i].Title; "Title"指的是返回的名字
name: obj.data[i].OperationCode,
inputValue: obj.data[i].OpeartionBehaviorId,
checked: false
});
checkboxgroup.items.add(checkbox);
}
OperationDefineForm.doLayout(); //重新调整版面布局
}
});
}

2.在修改页面窗体,加载所有CheckBox项,并选中相关项

2.1在修改页面窗体代码片段

  {
xtype: 'panel',
width: 750,
border: false,
flex: 3,
items: [{
xtype: 'checkboxgroup',
id: 'lblOperationBehavior_Update',
name: 'lblOperationBehavior_Update',
columns: 4,
fieldLabel: '设定权限',
labelWidth: 100,
width: 750,
align: 'left',
border: true,
anchor: '100%', flex: 1,
listeners: {
render: function (view, opt) {
LoadingOperationBehavior_Update();
}
}
}]
},

2.2 LoadingOperationBehavior_Update();

//加载操作全部名称
//说明:LoadingOperationBehavior_Update中有两个Ajax请求;第一个是获取全部的CheckBox;第二个获取的是选中的CheckBox
function LoadingOperationBehavior_Update() { Ext.Ajax.request({//第一个Ajax
url: '/ProjectWeb/HttpHandlerData/MemberManagement/MemberManagement.ashx?operation=SearchOperationBehavior',
params: {
start: start,
limit: limit,
page: '1'
},
success: function (response) {
var cbgObj = eval("(" + response.responseText + ")");
var cbgLen = cbgObj.data.length;//obj.data.length; "Table"这里的Table指的是后台返回 类似于data
if (cbgObj.data == null || cbgLen == 0) {
return;
}
var checkboxgroup = OperationDefineForm_Update.getForm().findField('lblOperationBehavior_Update');
var checkbox;
var strInIds = "";//定义临时变量,判断是否已经存在并选中
Ext.Ajax.request({//第二个Ajax
url: '/ProjectWeb/HttpHandlerData/MemberManagement/MemberManagement.ashx?operation=SearchOperationBehaviorTOP',
success: function (response) {
var obj = eval("(" + response.responseText + ")");
var len = obj.data.length;//obj.data.length; "Table"这里的Table指的是后台返回 类似于data
if (obj.data == null || len == 0) {
return;
}
for (var i = 0; i < cbgLen; i++) {
for (var j = 0; j < len; j++) {
if (cbgObj.data[i].OpeartionBehaviorId == obj.data[j].OpeartionBehaviorId) {//如果两个ID对比相等的话就是代表这个选项已呗选中
strInIds += cbgObj.data[i].OpeartionBehaviorId;
checkbox = new Ext.form.Checkbox(
{
boxLabel: obj.data[j].OperationName,//obj.Table[i].Title; "Title"指的是返回的名字
name: obj.data[j].OperationCode,
inputValue: obj.data[j].OpeartionBehaviorId,
checked: true
});
}
else {//不相等,不选
if (strInIds.indexOf(cbgObj.data[i].OpeartionBehaviorId) < 0) {
checkbox = new Ext.form.Checkbox(
{
boxLabel: cbgObj.data[i].OperationName,//obj.Table[i].Title; "Title"指的是返回的名字
name: cbgObj.data[i].OperationCode,
inputValue: cbgObj.data[i].OpeartionBehaviorId,
checked: false
});
}
}
}
checkboxgroup.items.add(checkbox);
}
OperationDefineForm_Update.doLayout(); //重新调整版面布局
}
});
}
}); }

 

EXTJS 4.2 资料 控件之checkboxgroup的用法(动态数据)的更多相关文章

  1. EXTJS 4.2 资料 控件之checkboxgroup的用法(静态数据)

    1.页面 1.1点击‘横幅’,需要动态显示隐藏文本框 { xtype: 'fieldset', title: '指定附加图&横幅设置', collapsible: true, items: [ ...

  2. EXTJS 4.2 资料 控件之radiogroup 的用法

    最近在EXTJS4.2开发项目,radiogroup的用法,主要是和grid之间的编辑功能:看了好多资料都不对,特此在这里备注记录 代码如下, 1.这是一段Win窗体上的两个单选按钮,设置单选按钮都是 ...

  3. EXTJS 3.0 资料 控件之 html 潜入label用法

    这是在Extjs 中插入html 控件label! html: "<div><label id='howMany'>您共选中了</label><br ...

  4. EXTJS 3.0 资料 控件之 combo 用法

    EXTJS combo 控件: 1.先定义store //年款 var comboData_ReleasYear = [ ['], ['], ['], ['] ]; 2.定义combo控件 { lay ...

  5. EXTJS 4.2 资料 控件之combo 联动

    写两个数据源: 1.IM_ST_Module.js { success:true, data:[ { ModuleId: '1', ModuleName: '资讯' } , { ModuleId: ' ...

  6. EXTJS 4.2 资料 控件textfield中fieldLabel去掉冒号,控件label的长度

    代码: labelSeparator: '', // 去掉laebl中的冒号 labelWidth: 10,//控件label的长度

  7. EXTJS 4.2 资料 控件之Grid 那些事

    最近在学习Extjs4.2 ,积累文章,看得不错,再此留年: //表格数据最起码有列.数据.转换原始数据这3项 Ext.onReady(function(){ //定义列 var columns = ...

  8. EXTJS 4.2 资料 控件之Window窗体自动填充页面

    1.html页面代码: <div id="component" style="width:100%;height:100%"> <body&g ...

  9. EXTJS 4.2 资料 控件之Grid Columns 列renderer 绑定事件

    columns: [ { header: '序号', xtype: 'rownumberer', align: 'center', width: 100 }, { header: 'CompanyId ...

随机推荐

  1. Linux下安装配置Node及memcached

    这篇主要是记录Linux下安装Node及memcached遇到的问题及安装配置过程,方便日后查阅 Node安装及配置 [root@hostname ~]tar zxvf node-v0.12.4.ta ...

  2. javaweb学习总结十(xml解析<SAX以及DOM方式>)

    一:XML解析技术 一般我们使用sun公司或者开源组织开发的工具包解析xml效率比较高. 1:jaxp解析xml,jaxp是sun公司开发的解析xml工具包 2:jaxp解析xml代码如下 a:获取d ...

  3. 向MyEclipse添加Oracle数据库

    向MyEclipse添加Oracle数据库 1.点击下面圈起来的位置,打开MyEclipse database Explorer视图. 2.在如图空白处右击,选择new进入New Database C ...

  4. ZOJ 3209 Treasure Map (Dancing Links)

    Treasure Map Time Limit:2000MS     Memory Limit:32768KB     64bit IO Format:%lld & %llu Submit S ...

  5. 【阔别许久的博】【我要开始攻数学和几何啦】【高精度取模+同余模定理,*】POJ 2365 The Embarrassed Cryptographer

    题意:给出一大数K(4 <= K <= 10^100)与一整数L(2 <= L <= 106),K为两个素数的乘积(The cryptographic keys are cre ...

  6. 转:艾瑞咨询2016 IM云的发展趋势

    转自: http://www.cnblogs.com/lingyunhu/p/rtc63.html

  7. 通过使用精简客户端,且不需要安装的客户端,配合PLSQL连接oracle数据库

    通过使用精简客户端,且不需要安装的客户端,配合PLSQL连接oracle数据库. 首先下载安装包在Oralce官方网站上下载Oracle Instantclient Basic package.地址如 ...

  8. RedirectFromLoginPage和FormsAuthenticationTicket的区别

    如果你对.net身份验证不是很清晰,请看本文.本文用简单明了的语言,让你对RedirectFromLoginPage和FormsAuthenticationTicket有一个完整的认识. 1)Form ...

  9. Jsoup 的认识和简单使用

    之前做学校软件协会APP的时候,由于自己不会在服务端写接口,所以服务端一直是由另一位Z同学完成的,但是突然Z同学被老师调到泸州帮以前的学长做一个月的临时web开发去了,所以协会APP的接口只做了一部分 ...

  10. 和阿文一起学H5-- H5排版八大套路

    二.中心型 三.倾斜型 四.三角形 5.全图形 6.渐变型 7.蒙版型 \ 8.骨骼型 实例