ExtJS扩展:扩展grid之toolbar button禁用表达式
2013-11-12 14:25
399 查看
在前一篇文章我们扩展了grid通过选中记录数来禁用toolbar上的按钮,有时候我们需要通过记录中的数据来决定是否禁用按钮,今天我们就来扩展它。
照例,最新的代码和例子都在github上:ExtJsExtend
先看看使用代码(这里只有部分代码,可以结合前一篇文章来阅读或者直接通过github获取最新代码):
.ln { color: rgb(0,0,0); font-weight: normal; font-style: normal; }
.s0 { color: rgb(169,183,198); }
.s1 { color: rgb(106,135,89); }
.s2 { color: rgb(204,120,50); }
.s3 { color: rgb(204,120,50); font-weight: bold; }
.s4 { color: rgb(104,151,187); }
.s5 { color: rgb(232,191,106); }
(这里重构了前一篇文章中的用法
,将noSelectionDisable、oneSelectionDisable、moreSelectionsDisable整合进buttonDisable中了)。
expressions就是表达式,用item的name或itemId作为Key,表达式就是javascript的表达式,需要注意的是要在field的名称前加$(因为最终要替换$,通过eval来运行表达式)。来看看效果:
嗯,这条记录是可以编辑的。
这条记录不能编辑,因为phone== “555-222-1254”。
看看这部分扩展的代码:
代码也比较简单,就是遍历选中记录,然后在数据上执行表达式,如果为true就禁用,只要有一条记录的数据满足,那么这个按钮就将会被禁用。
还需注意,表达式禁用比选中记录数禁用的优先级高。
照例,最新的代码和例子都在github上:ExtJsExtend
先看看使用代码(这里只有部分代码,可以结合前一篇文章来阅读或者直接通过github获取最新代码):
.ln { color: rgb(0,0,0); font-weight: normal; font-style: normal; }
.s0 { color: rgb(169,183,198); }
.s1 { color: rgb(106,135,89); }
.s2 { color: rgb(204,120,50); }
.s3 { color: rgb(204,120,50); font-weight: bold; }
.s4 { color: rgb(104,151,187); }
.s5 { color: rgb(232,191,106); }
buttonDisable: { noSelection: ['Edit', 'Delete', 'Print'], moreSelections: ['Edit'], expressions: { Edit: '$phone == "555-222-1254"' } },
(这里重构了前一篇文章中的用法
,将noSelectionDisable、oneSelectionDisable、moreSelectionsDisable整合进buttonDisable中了)。
expressions就是表达式,用item的name或itemId作为Key,表达式就是javascript的表达式,需要注意的是要在field的名称前加$(因为最终要替换$,通过eval来运行表达式)。来看看效果:
嗯,这条记录是可以编辑的。
这条记录不能编辑,因为phone== “555-222-1254”。
看看这部分扩展的代码:
if (me.buttonDisable.expressions) { var exps = me.buttonDisable.expressions; for (var btn in exps) { var exp = exps[btn]; for(var i = 0, il = records.length;i<il;i++) { var data = records[i].data; exp = exp.replace(/\$/g, 'data.'); var disabled = eval(exp); if (disabled === true) { disables[btn] = true; break; } } } }
代码也比较简单,就是遍历选中记录,然后在数据上执行表达式,如果为true就禁用,只要有一条记录的数据满足,那么这个按钮就将会被禁用。
还需注意,表达式禁用比选中记录数禁用的优先级高。
相关文章推荐
- jsp 验证码
- 22-JavaScript-面向对象-构造函数-prototype
- 正则表达式常用的js验证
- Javascript中最常用的55个经典技巧 .
- js取消按键事件的默认行为
- 不需要jsonp进行跨域的web-api (ssl enabled)
- template.js
- 格式化MyEclipse代码(java、jsp、js)行的长度@修改java代码字体@修改Properties文件编码方式
- 格式化MyEclipse代码(java、jsp、js)行的长度@修改java代码字体@修改Properties文件编码方式
- threejs 教程
- JavaScript HTML DOM - 改变 CSS 及元素属性
- js获取本地图片路径代码
- javascript中defer的作用
- js实现非模态窗口增加数据后刷新父窗口数据
- JavaScript插件——模态框
- js判断浏览器类型
- Js 日期转换函数(UTC时间转换及日期想加减)
- 21-JavaScript-面向对象-对象的属性和方法以及this
- [WebKit] JavaScriptCore解析--基础篇(二)解释器基础与JSC核心组件
- JS function