zoukankan      html  css  js  c++  java
  • ExtJS扩展:扩展grid之toolbar button禁用表达式

          在前一篇文章我们扩展了grid通过选中记录数来禁用toolbar上的按钮,有时候我们需要通过记录中的数据来决定是否禁用按钮,今天我们就来扩展它。

          照例,最新的代码和例子都在github上:ExtJsExtend

          先看看使用代码(这里只有部分代码,可以结合前一篇文章来阅读或者直接通过github获取最新代码):

     
                    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来运行表达式)。来看看效果:

    image

    嗯,这条记录是可以编辑的。

    image

    这条记录不能编辑,因为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就禁用,只要有一条记录的数据满足,那么这个按钮就将会被禁用。

    还需注意,表达式禁用比选中记录数禁用的优先级高。

  • 相关阅读:
    Bootstrap使用
    Gulp
    Less和Sass
    ECMAScript6语法重点(二)
    deepin scrot-- linux下的截图工具
    iframe获取父、子窗口的方法
    测试总结--同步或异步处理过程中常见的问题
    测试总结--兼容性
    测试总结--时间/金额类字段需要关注的点
    测试总结--系统调用链路发生变更,如何评估测试范围
  • 原文地址:https://www.cnblogs.com/tubo/p/3419465.html
Copyright © 2011-2022 走看看