zoukankan      html  css  js  c++  java
  • JavaScript链式调用

    方法的链式调用

    1. 调用链的结构

    链式调用的核心就是在调用方法中返回调用该方法的对象的引用,即 return this;

    下面我们模范 JQuery 来实现一个简单的链式调用接口,通过 $() 方法获取元素对象,并提供三个链式调用方法 each(callback)setStyleaddEvent

    (function() {
        function _$(els) {
            this.elements = [];
            for(var i=0, len=els.length; i<len; i++){
                var element = els[i];
                if(typeof element === 'string') {
                    element = document.querySelector(element);
                }
                this.elements.push(element)
            }
        }
    
        _$.prototype = {
            each: function(fn) {
                for( var i=0, len=this.elements.length; i<len; i++) {
                    fn.call(this, this.elements[i])
                }
                return this             // 返回调用函数的对象的引用
            },
            setStyle: function(prop, val) {
                this.each(function(el) {
                    el.style[prop] = val;
                })
                return this
            },
            addEvent: function(type, fn) {
                var add = function(el) {
                    if (window.addEventListener) {
                        el.addEventListener(type, fn, false);
                    } else if (window.attachEvent) {
                        el.attachEvent('on'+ type, fn);
                    }
                }
                this.each(function (el) {
                    add(el)
                })
                return this;
            }
        }
    
        window.$ = function() {
            return new _$(arguments)
        }
    })()
    

    2. 获取链式调用方法的数据

    如果需要通过某个方法获取对象的数据,我们一般的方法是通过 return 将数据返回,但是在链式调用中 return 已经被用来返回调用方法的对象的引用,所以不能通过这个方法来获取数据。所以在链式调用方法中获取数据需要通过回调函数来实现。

    window.API = window.API || function() {
        var name = 'Hello world';
        this.setName = function(newName) {
            name = newName;
            return this
        };
        this.getName = function() {
            return name
        }
        this.getNameByCallback = function(callback) {
            callback.call(this, name)
            return this
        }
    }
    
    // usage 
    var api = new API()
    // 中断了链式结构
    api.setName('cczs').getName()
    
    // 没有中断链式,但是不能通过 return 返回,使得取值器也支持链式调用
    api.setName('cczs').getNameByCallback(function(name){
        console.log(name)
    })
    
    
  • 相关阅读:
    Qt源文件和ui文件的关系
    使用moveToThread线程并正确回收内存的方式
    mysql设置某字段不可重复
    使用curl创建简单的性能监控工具
    你是不是那个带不动的队友
    这样的面试你能通过吗
    浅谈测试观
    自动化测试如何准备测试数据
    关于双十二崩盘的一些思考
    浅谈测试环境
  • 原文地址:https://www.cnblogs.com/CccZss/p/8491240.html
Copyright © 2011-2022 走看看