• <noscript id="ggggg"><dd id="ggggg"></dd></noscript>
    <small id="ggggg"></small> <sup id="ggggg"></sup>
    <noscript id="ggggg"><dd id="ggggg"></dd></noscript>
    <tfoot id="ggggg"></tfoot>
  • <nav id="ggggg"><cite id="ggggg"></cite></nav>
    <nav id="ggggg"></nav>
    成人黃色A片免费看三更小说,精品人妻av区波多野结衣,亚洲第一极品精品无码,欧美综合区自拍亚洲综合,久久99青青精品免费观看,中文字幕在线中字日韩 ,亚洲国产精品18久久久久久,黄色在线免费观看

    柯里化、原生bind、防抖節流函數、實現promise

    2019-7-25    seo達人

    如果您想訂閱本博客內容,每天自動發到您的郵箱中, 請點這里

    多參數柯里
    原生bind
    實現promise
    防抖節流函數
    多參數柯里化

    參數fn可以是function(a,b,c){},也可以是function(a,b,c,d,f){}

    // 支持多參數傳遞
    function progressCurrying(fn, args) {

        var _this = this
        var len = fn.length;
        var args = args || [];
        return function() {
            var _args = Array.prototype.slice.call(arguments).concat(args);
            // 如果參數個數小于最初的fn.length,則遞歸調用,繼續收集參數
            if (_args.length < len) {
                return progressCurrying.call(_this, fn, _args);
            }

            // 參數收集完畢,則執行fn
            return fn.apply(this, _args);
        }
    }

    原生js實現bind

    Function.prototype.myBind = function(Othis){
      if(typeof this !== "function"){
        return new TypeError("not a function");
      }
      let _this = this;
      let args = [...arguments].slice(1);
      let func = function(){};
      let fBound = function () {
        return _this.apply(this instanceof func ?this:Othis,[...arguments].concat(args));
      }
      func.prototype = _this.prototype;
      fBound.prototype = new func();
      return fBound;
    }

    防抖函數

    //每wait時間內執行一次,若期間被觸發,則重新執行
    function debounce(func,wait) {
      var timeout ;
      return function(){
        let args = [...arguments];
        let _this = this;
        if(timeout){
          clearTimeout(timeout);
        }
        timeout = setTimeout(function() {
          func.apply(_this,args);
        }, wait);
      }
    }

    節流函數

    //每wait時間執行一次
    function throttle(func,wait){
      var timeStart = 0 ;
      return function(){
        let _this = this;
        let args = [...arguments];
        let now = Date().now();
        if(now - timeStart >wait){
          func.apply(_this,args);
          timeStart = now;
        }
      }
    }

    實現一個promise

        function _Promise(func){
            this.status = 'pending'
            this.result = '' ;
            func(this.resolve.bind(this),this.reject.bind(this));
        }
        _Promise.prototype.resolve = function(result){
            if(this.status == 'pending'){
                this.status = 'fullfilled';
                this.result = result;
            }
        }
        _Promise.prototype.reject = function(error){
            if(this.status == 'pending'){
                this.status = 'rejected';
                this.result = error;
            }
        }
        _Promise.prototype.then = function(preResolve,preReject){
            let _isPromise ;
            if(this.status == 'fullfilled'){
                _isPromise = preResolve(this.result);
            }else if(this.status == 'rejected' && arguments[1]){
                 _isPromise = preReject(this.result);
            }
            return _isPromise instanceof _Promise ? _isPromise:this;
        }

    實現一個promise.all()

     function promiseAll(promiseArray){
            //首先參數一定是一個數組
            //然后此函數返回的是一個promise,如果全部成功,則返回結果的數組,只要有一個失敗,則返回失敗的結果
            return new Promise(function (resolve,reject){
                if(!Array.isArray(promiseArray)){
                    return reject(new TypeError("not a function"));
                }
                let resolveNum = 0;
                let arrNum = promiseArray.length;
                let resolveResult = [];
                for(let i=0; i<arrNum ;i++){
                    (function (i){
                        Promise.resolve(promiseArray[i]).then(function(result){
                            resolveNum ++;
                            resolveResult.push(result);
                            if(resolveNum == arrNum){
                                return resolve(resolveResult);
                            }
                        },function(error){
                            return reject(error);
                        })
                    })(i);
                }
            }) //返回的promise結束
            
        }
    藍藍設計www.lzhte.cn )是一家專注而深入的界面設計公司,為期望卓越的國內外企業提供卓越的UI界面設計、BS界面設計 、 cs界面設計 、 ipad界面設計 、 包裝設計 、 圖標定制 、 用戶體驗 、交互設計、網站建設 平面設計服務

    日歷

    鏈接

    個人資料

    藍藍設計的小編 http://www.lzhte.cn

    存檔

    主站蜘蛛池模板: 成人无码精品1区2区3区免费看| 国产高清色高清在线观看| 99国产精品久久99久久久| 亚洲成在人线免费观看| 亚洲精品免费一二三区| 国产va在线观看免费| 欧美性爱影院| 久久久久无码精品亚洲日韩| 亚洲中文字幕久久久一区| 99精品热在线在线观看视| 999国产精品永久免费视频精品久久| 在线播放国产99re| 亚洲天堂一区二区三区在线| 久久丁香花综合狼人| 久久精品国产久精国产80cm| 亚洲高清免费在线观看| 无码少妇一区二区性色AV| 国产精品无码久久久一区蜜臀| 一区二区三区不卡在线观看| 2021无码最新国产在线观看| 少妇愉情理伦片丰满丰满午夜| 18禁国产美女白浆在线| 在线视频不卡国产在线视频不卡 | 亚洲精品无码久久千人斩| 香蕉久人久人青草青草| 久久免费视频插出白浆| 国内精品伊人久久久久777| 9191精品国产观看| 亚洲中文字幕无码一区日日添| 少妇一晚三次一区二区三区| 国产成人高清在线观看视频| 日韩中文字幕一区二区不卡| 精品欧美一区二区精品久久| 在线看片免费人成视频福利| 亚洲香蕉网综合久久| 人妻巨大乳一二三区| 91大神福利视频| 日韩欧美性爱| 97精品国产97久久久久久| 又色又爽又黄高潮的免费视频| 天堂av在线成人免费|