JS全選功能代碼優化

JS全選功能代碼優化javascript

    最近在看javascript MVC那本書,也感受到本身寫的代碼也並不優雅,因此一直在想 用另外一種模式來編寫JS代碼,因此針對以前的簡單的JS全選功能來作個簡單的demo,使用目前如今的編碼方式來從新編碼,固然之後會一直用這種方式來編寫本身的代碼。下面是以下代碼:java

 JS全部代碼:數組

/**
 * JS全選
 * @class Checkall
 * @param {Object} cfg
 * @param {Element|selector} [cfg.container] 限定全選的容器
 * @param {selector} cfg.checkAll 全選框
 * @param {selector} cfg.checkItem 子選框
 */
 function CheckAll(cfg,callback) {
    var self = this;

    this.config = cfg;

    this.container = $(cfg.container) || document.body;

    // 全選自定義事件
    this.container.delegate(cfg.checkAll,'change',function(e){
        $(e.target).trigger('checkAllChange');
    });

    // 單選自定義事件
    this.container.delegate(cfg.checkItem,'change',function(e){
        $(e.target).trigger('checkItemChange');
    });

    // 全選操做
    this.container.delegate(cfg.checkAll,'checkAllChange',function(e){
    
        var checked = self.isItemChecked(e.target);

        self._checkAll(checked);

        // 選中全部子節點
        self._AllChildrenChecked(checked);

        callback && $.isFunction(callback) && callback(self);
    });

    // 單選操做
    this.container.delegate(cfg.checkItem,'checkItemChange',function(e){
        
        // 檢查是否全部子節點都選中了
        if( self._isChildrenChecked()){
            self._checkAll(true);
        }
        else {
            self._checkAll(false);
        }
        callback && $.isFunction(callback) && callback(self);
    });
 };
 
 $.extend(CheckAll.prototype,{
    
    /*
     * 選中單個checkbox
     * @param item
     * @param _isCheck
     */
    _checkItem: function(item, _isCheck ){
        item = $(item);
        item.prop('checked', _isCheck);
    },
    /*
     * 選中/反選全部的 全選按鈕
     * @method _checkAll {private}
     * @param {Boolean} _isCheck
     */
    _checkAll: function(_isCheck){
        var self = this;
        this.container.find(self.config.checkAll).each(function(index,item){
            var isAllChecked = self.isItemChecked(item);
            if(isAllChecked !== _isCheck) {
                 self._checkItem(item,_isCheck);
            }
        });
    },
    /*
     * 選中/反選 全部的子節點
     * @method _AllChildrenChecked {private}
     */
     _AllChildrenChecked: function(_isCheck){
        var self = this;
        this.container.find(this.config.checkItem).each(function(index,item){
            var itemChecked = self.isItemChecked(item);
            if( itemChecked !== _isCheck){
                self._checkItem(item, _isCheck);
            }
        });
     },
    /*
     * 是否全部的子節點都選中了
     */
    _isChildrenChecked: function(){
        var isCheckAll = true;
        var self = this;
        this.container.find(this.config.checkItem).each(function(index,item){
            if(!self.isItemChecked(item)) {
                isCheckAll = false;
            }
        });
        return isCheckAll;
    },
    /*
     * 檢查一個元素是否被選中
     */
     isItemChecked: function(item) {
        return $(item).is(":checked");
     },
     /*
      * 獲取被選中的全部值 或者 屬性 存入數組
      * @todo 好比想獲取選中全部項的id或者其餘全部項的屬性等操做
      * @method getValues {public} 
      * @param {elems,attr} 元素全部的dom節點 獲取元素對應的屬性值
      * @return 返回數組 {rets}
      */
     getValues: function(elems,attr) {
        var self = this,
            rets = [];
        $(elems).each(function(index,item){
            var isboolean = self.isItemChecked(item);
            if(isboolean && $(item).prop(attr)) {
                var curAttr = $(item).prop(attr);
                rets.push(curAttr);
            }
        });
        return rets;
     }
 });

HTML代碼以下:dom

<div class="check-list">
    <hr>
    <div class="J_CheckListContainerBasic">
        <h4>基本使用</h4>

        <div class="check-all">
            <label>全選 <input type="checkbox" class="J_CheckAll"></label>
            <ul class="sub-checkbox">
                <li><label>選中 <input type="checkbox" class="J_CheckItem" value="1"></label></li>
                <li><label>選中 <input type="checkbox" class="J_CheckItem" value="2"></label></li>
                <li><label>選中 <input type="checkbox" class="J_CheckItem" value="3"></label></li>
            </ul>
        </div>
    </div>
</div>

JS初始化以下:優化

var checkAll=  new CheckAll({
            container: '.J_CheckListContainerBasic',
            checkAll: '.J_CheckAll',
            checkItem: '.J_CheckItem'
        },function(){
            console.log(checkAll.getValues('.J_CheckItem',"value"));
        });

固然爲了查看效果,我也提供了JSFIddler地址 供預覽:this

JS全選功能演示編碼

相關文章
相關標籤/搜索