浅谈Extjs radiogroup change事件与items下的checked属性
在使用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属性的更多相关文章
- 浅谈Android中的事件分发机制
View事件分发机制的本质就是就是MotionEvent事件的分发过程,即MotionEvent产生后是怎样在View之间传递及处理的. 首先介绍一下什么是MotionEvent.所谓MotionEv ...
- 浅谈Javascript单线程和事件循环
单线程 Javascript 是单线程的,意味着不会有其他线程来竞争.为什么是单线程呢? 假设 Javascript 是多线程的,有两个线程,分别对同一个元素进行操作: function change ...
- 浅谈JavaScript中的事件
引言 Html页面与JavaScript之间的交互是通过事件来完成的.事件,就是文档或者浏览器窗口中发生的一些特定的交互瞬间.可以使用侦听器(处理程序)来预订事件,以便事件发生时执行相应的代码.这在传 ...
- 浅谈C#委托和事件
委托给了C#操作函数的灵活性,我们可使用委托像操作变量一样来操作函数,其实这个功能并不是C#的首创,早在C++时代就有函数指针这一说法,而在我看来委托就是C#的函数指针,首先先简要的介绍一下委托的基本 ...
- 浅谈javascript的Touch事件
js的touch事件,一般用于移动端的触屏滑动 代码如下: $(function(){ document.addEventListener("touchmove", _touch, ...
- 浅谈C#委托和事件【转】
委托给了C#操作函数的灵活性,我们可使用委托像操作变量一样来操作函数,其实这个功能并不是C#的首创,早在C++时代就有函数指针这一说法,而在我看来委托就是C#的函数指针,首先先简要的介绍一下委托的基本 ...
- 浅谈C#委托和事件(转载)
委托给了C#操作函数的灵活性,我们可使用委托像操作变量一样来操作函数,其实这个功能并不是C#的首创,早在C++时代就有函数指针这一说法,而在我看来委托就是C#的函数指针,首先先简要的介绍一下委托的基本 ...
- 【解决方案】jquery live的change事件在IE下失效
$("#spanChildSec select").live("change", function () { //处理内容 ...
- 浅谈Linux(Centos7.4)环境下NTP服务器的构建
一.软件环境 1.操作系统版本 [root@Geeklp201 etc]# cat /etc/redhat-release CentOS Linux release 7.4.1708 (Core ...
随机推荐
- bat基础命令
rem 删除日志文件和catalina文件移动war包(下载了tomcat的一级目录下) del /q /s logs\*.* del /q /s webapps\moc.war rmdir /q / ...
- Cocos2d-x 核心概念 - 层(Layer)
层(Layer) 一个简单的主界面是由是三个层叠加实现的,从上到下依次为,菜单层,精灵层,背景层 这个次序适用与事件的响应机制,菜单层最先接受到系统事件,然后精灵层,最后背景层 在事件传递的过程中,如 ...
- 使用reflux进行react组件之间的通信
前言 组件之间为什么要通信?因为有依赖. 那么,作为React组件,怎么通信? React官网说, 进行 父-子 通信,可以直接pass props. 进行 子-父 通信,往父组件传给子组件的函数注入 ...
- java的4种代码块
一.普通代码块 直接在一个方法中出现的{}就称为普通代码块,例子程序如下: public class CodeDemo01{ public static void main(String[] args ...
- BIOS MCSDK 2.0 学习笔记(二)————使用Platform Library创建工程
[TOC] Platform Library提供了一组适用于开发板的API函数.我们可以使用它来快速入手开发板. 1.启动CCS,建立一个空的工程 2.添加include路径 "C:\Pro ...
- Forward和Redirect的区别
一:间接请求转发(Redirect) 二:直接请求转发(Forward) 用户向服务器发送了一次HTTP请求,该请求可能会经过多个信息资源处理以后才返回给用户,各个信息资源使用请求转发机制相互转发请求 ...
- 移动web点5像素的秘密
最近和一个朋友聊天,朋友吐露了工作上的一些不开心,说自己总是喜欢跟别人比较,活得比较累,这种感觉大部分人经历过,往往觉得是自己心态不好,其实不然,这是人性,此时应该快速摆脱这种状态,想到DOTA大9神 ...
- PE文件学习系列二 DOS头分析
合肥程序员群:49313181. 合肥实名程序员群 :128131462 (不愿透露姓名和信息者勿加入)Q Q:408365330 E-Mail:egojit@qq.com PE文件结 ...
- Unity3D 之 iTween 相关
有过 Flash 开发经验的朋友,对这个 iTween 应该感到非常熟悉吧,在 Flash 平台有一款功能几乎一样的插件 TweenLite,至于哪个先哪个后,有没有相互借鉴之类的就不在讨论范围了. ...
- 好用的Magento一步支付插件One Step Checkout免费版
Magento免费版一步支付插件地址:http://www.magentocommerce.com/magento-connect/one-page-checkout.html 直接引用KEY:ht ...