在使用Extjs制作crud时,由于添加和修改界面的高度相似,使用了相同的row字段。

在角色字段中使用了change监听事件,用于动态的无效化权限分配字段,因为权限分配界面默认没有隐藏,设定了checked:true属性

var row_role = {layout:'column',items:[{columnWidth:.9,layout:'form',items:[{
xtype:'radiogroup', fieldLabel:'角色',
items:[
{id:'role1', boxLabel:'管理员', name:'userDto.user.roleCode', inputValue:1},
{id:'role2', boxLabel:'操作员', name:'userDto.user.roleCode', inputValue:2,    checked: true},
{id:'role3', boxLabel:'计划发布员', name:'userDto.user.roleCode', inputValue:3},
{id:'role4', boxLabel:'客户',  name:'userDto.user.roleCode', inputValue:4}
],
listeners:{
'change':function(group,checked){
var fun = Ext.getCmp('fun_role');
if(checked.inputValue == 2){
fun.enable();
}else{
fun.disable();
}
}
}
}]}]}; var row_funCode = {layout:'column',items:[{columnWidth:.9,layout:'form',items:[{
xtype:'checkboxgroup', fieldLabel:'权限分配',
columns:4, id:'fun_role',
items:[
{boxLabel:'免签', id:'userDto.user.funCode1'},
{boxLabel:'订房', id:'userDto.user.funCode2'},
{boxLabel:'订车', id:'userDto.user.funCode3'},
{boxLabel:'订餐', id:'userDto.user.funCode4'},
{boxLabel:'订导游', id:'userDto.user.funCode5'},
{boxLabel:'订门票', id:'userDto.user.funCode6'},
{boxLabel:'订火车票', id:'userDto.user.funCode7'},
{boxLabel:'额外费用', id:'userDto.user.funCode8'}
]
}]}]};

经过测试,证明在添加界面中没有任何问题,角色的切换和事件的处理都很正常。

但在处理修改数据时出现了问题。初步的看,业务逻辑完全没有问题,但在业务展示是,应该无效化的字段依旧可以使用。

function inputUserData(selected,form){
//声明一个新的数据,将从数据源中获取的数据放入其中
var newRecord = {
data:{
//textfiled,下拉菜单的赋值方式
'userDto.user.username' :selected[0].get('username'),
'userDto.user.nickname' :selected[0].get('nickname'),
'userDto.user.qq' :selected[0].get('qq'),
'userDto.user.company.itemCode' :selected[0].get('companyCode'),
'userDto.user.remark' :selected[0].get('remark'),
}
}
//根据获取到的角色值和默认值比较
switch(selected[0].get('roleCode')){
//给相应的单选按钮设置选中状态
case 1: var role = Ext.getCmp('role1'); role.setValue(true);
//获取权限分配对象,设置无效化
var fun = Ext.getCmp('fun_role');
fun.disable();
break;
case 2: var role = Ext.getCmp('role2'); role.setValue(true);
var fun = Ext.getCmp('fun_role');
fun.enable();
break;
case 3: var role = Ext.getCmp('role3'); role.setValue(true);
var fun = Ext.getCmp('fun_role');
fun.disable();
break;
case 4: var role = Ext.getCmp('role4'); role.setValue(true);
var fun = Ext.getCmp('fun_role');
fun.disable();
break;
}
//将新的数据刷新到form表单中
form.getForm().loadRecord(newRecord);
}

经过反复测试后,发现是角色中设置的checked属性造成的,当该字段被隐藏后,执行了change事件

var fun = Ext.getCmp('fun_role'); fun.disable();

change事件监听的checked是手动设置的{id:'role2', boxLabel:'操作员', name:'userDto.user.roleCode', inputValue:2, checked: true}的这条记录

if(checked.inputValue == 2)

所有被无效化的字段,有重新因为change事件而被有效化。修改该问题时:建议将手动设置的checked属性删除即可



浅谈Extjs radiogroup change事件与items下的checked属性的更多相关文章

  1. 浅谈Android中的事件分发机制

    View事件分发机制的本质就是就是MotionEvent事件的分发过程,即MotionEvent产生后是怎样在View之间传递及处理的. 首先介绍一下什么是MotionEvent.所谓MotionEv ...

  2. 浅谈Javascript单线程和事件循环

    单线程 Javascript 是单线程的,意味着不会有其他线程来竞争.为什么是单线程呢? 假设 Javascript 是多线程的,有两个线程,分别对同一个元素进行操作: function change ...

  3. 浅谈JavaScript中的事件

    引言 Html页面与JavaScript之间的交互是通过事件来完成的.事件,就是文档或者浏览器窗口中发生的一些特定的交互瞬间.可以使用侦听器(处理程序)来预订事件,以便事件发生时执行相应的代码.这在传 ...

  4. 浅谈C#委托和事件

    委托给了C#操作函数的灵活性,我们可使用委托像操作变量一样来操作函数,其实这个功能并不是C#的首创,早在C++时代就有函数指针这一说法,而在我看来委托就是C#的函数指针,首先先简要的介绍一下委托的基本 ...

  5. 浅谈javascript的Touch事件

    js的touch事件,一般用于移动端的触屏滑动 代码如下: $(function(){ document.addEventListener("touchmove", _touch, ...

  6. 浅谈C#委托和事件【转】

    委托给了C#操作函数的灵活性,我们可使用委托像操作变量一样来操作函数,其实这个功能并不是C#的首创,早在C++时代就有函数指针这一说法,而在我看来委托就是C#的函数指针,首先先简要的介绍一下委托的基本 ...

  7. 浅谈C#委托和事件(转载)

    委托给了C#操作函数的灵活性,我们可使用委托像操作变量一样来操作函数,其实这个功能并不是C#的首创,早在C++时代就有函数指针这一说法,而在我看来委托就是C#的函数指针,首先先简要的介绍一下委托的基本 ...

  8. 【解决方案】jquery live的change事件在IE下失效

    $("#spanChildSec select").live("change", function () {              //处理内容       ...

  9. 浅谈Linux(Centos7.4)环境下NTP服务器的构建

     一.软件环境 1.操作系统版本 [root@Geeklp201 etc]# cat /etc/redhat-release CentOS Linux release 7.4.1708 (Core ...

随机推荐

  1. 两个平行div之间有间隙

    两个平行的div使用 display: inline-block 会导致元素之间有空隙解决方法: 父元素设置 font-size: 0;

  2. Android中文TTS

    如今在Android中开发中文语音播报有各式各样的云服务.SDK.API等云云,但是大部分服务是需要联网支持来进行语音合成的,在中文语音合成方面,科大讯飞无疑是佼佼者,而且它也提供了离线语音合成包(需 ...

  3. String All Methods

    1.public char charAt(int index) public class Test{ public static void main(String args[]){ String s= ...

  4. python 中字典实用操作

    1.字典转化为列表 a={"username":"12","password":"89"} print a.items( ...

  5. SAP 采购订单收货时报错:对于采购订单xxxx无收货可能

    因为这个问题查了挺长时间,所以写在博客里记录下. 报错详细: 每个公司的配置不同,我公司遇到的这个问题原因是这里的确认控制是从信息记录带过来的,问题解决方法是,修改下确认控制的选项: 修改确认控制的后 ...

  6. Sql Server R2还有备份数据库错误

    错误信息描述  该数据库是运行版本10.50.1600的服务器上备份的.该版本与此服务器(运行版本10.00.1600)不兼容.请在支持该被份的服务器上还原该数据,  或者使用与此服务器兼容的备份(M ...

  7. 移动端弹性布局--flex

    目前,Flex布局,可以简便.完整.响应式地实现各种页面布局.而且,它已得到了所有浏览器的支持,这意味着,我们能很安全地使用这项功能. 如果你对弹性网页布局感兴趣,那可别错过flex这么好用的属性哦. ...

  8. JDBC/PreparedStatement

      JDBC是Java数据库连接技术的简称,提供连接各种常用数据库的能力     JDBC  AP 是Sun公司提供的I 内容:供程序员调用的接口,集成在Java.sql和javax.sql包中, 如 ...

  9. nginx和tomcat的区别

    web上的server都叫web server,但是大家分工也有不同的. nginx常用做静态内容服务和代理服务器(不是你FQ那个代理),直面外来请求转发给后面的应用服务(tomcat,django什 ...

  10. hexo 本地local4000打不开解决方法

    错误:Cannot GET /spadesq.github.io/ (注:spadesq.github.io是原来放hexo文件夹的名字) 由于我后来把hexo文件夹搬迁到别处,但我发现打开本地,地址 ...