閉包經(jīng)典題

for (var i = 1; i <= 5; i++) {
  setTimeout( function timer() {
      console.log(i+'m');
  }, 1000 );
}
以上輸出  5個(gè)6
如何做到輸出每個(gè)數(shù)呢?
①如下
for (let i = 1; i <= 5; i++) {
  setTimeout( function timer() {
      console.log(i+'m');
  }, 1000 );
}
②如下
for (var i = 1; i <= 5; i++) {
    (function(i){
        setTimeout( function timer() {
          console.log(i+'m');
      }, 1000 );
    })(i)
}

使用var或是非對象內(nèi)部的函數(shù)表達(dá)式內(nèi),可以訪問到存放當(dāng)前函數(shù)的變量;在對象內(nèi)部的不能訪問到。

原因也非常簡單遥缕,因?yàn)楹瘮?shù)作用域鏈的問題,采用var的是在外部創(chuàng)建了一個(gè)fn變量宵呛,函數(shù)內(nèi)部當(dāng)然可以在內(nèi)部尋找不到fn后向上冊作用域查找fn通砍,而在創(chuàng)建對象內(nèi)部時(shí),因?yàn)闆]有在函數(shù)作用域內(nèi)創(chuàng)建fn,所以無法訪問

解如下題:

function fun(n,o) {
  console.log(o)
  return {
    fun:function(m){
      return fun(m,n);
    }
  };
}
var a = fun(0);  a.fun(1);  a.fun(2);  a.fun(3);//undefined,?,?,?
var b = fun(0).fun(1).fun(2).fun(3);//undefined,?,?,?
var c = fun(0).fun(1);  c.fun(2);  c.fun(3);//undefined,?,?,?
//問:三行a,b,c的輸出分別是什么封孙?






//a: undefined,0,0,0
//b: undefined,0,1,2
//c: undefined,0,1,1
function Animal() {  
    this.name = "Animal";  
    this.showName = function() {  
        console.log(this.name);  
    };  
}  
  
function Cat() {  
  
    this.name = "Cat";  
    this._super = Cat.prototype;  
  
    this.showName1 = function() {  
        console.log(this.name);  
    };  
  
    this.showName2 = function() {  
        console.log(this.name);  
    };  
  
    this.showName3 = function() {  
        console.log(this._super.name + "=>" + this.name);  
    };  
}  
Cat.prototype = new Animal();  
var cat = new Cat();  
console.log(cat instanceof Animal);   //true  
cat.showName1();     //"Cat"  
cat.showName2.call(Cat.prototype);   //"Animal"  
cat.showName3();    //"Animal" => "Cat"  

編寫一個(gè)程序?qū)?shù)組扁平化去并除其中重復(fù)部分?jǐn)?shù)據(jù)迹冤,最終得到一個(gè)升序且不重復(fù)的數(shù)組:
var arr = [[1,2,2],[3, 4, 5, 5],[6, 7, 8, 9,[11,12,[12,13,[14]]]],10];
=>
var res= [1,2,3,4,5,6,7,8,9,10,11,12,13,14]

function copeArray(initArray){
    var result = [];
    result = delayering(initArray);
    console.log(quickSort(result));
}
var quickSort = function(){
    
    var result = [];
    var arr = arguments[0];
    if(arr.length<=1){
        return arr;
    }
    var middleIndex = Math.floor(arr.length/2);
    var minddleItem = arr.splice(middleIndex,1);
    var leftItem = [];
    var rightItem = [];
    
    arr.map((item,index)=>{
        if(item<minddleItem){
            leftItem.push(item)
        }else{
            rightItem.push(item);
        }
    })
    return quickSort(leftItem).concat(minddleItem).concat(quickSort(rightItem))
     
}
var delayering = function(){
    var result = [];
    var arr = arguments[0];
    arr.map((item,index)=>{
        if(Array.isArray(item)){
            var temp = delayering(item);
            temp.map((item,index)=>{
                if(result.indexOf(item)===-1){
                    result.push(item)
                }
            })
        }else{
            if(result.indexOf(item)===-1){
                result.push(item);
            }
        }
    })
    return result ;
}

閉包實(shí)現(xiàn)單例

var  GetInstance =(function (name,age){
    var person;
    function Person(){
        this.name = name;
        this.age = age;
    }
    function getInst(){
        debugger;
        if(person !=null){
            return person;
        }else{
            person = new Person();
            return person;
        }
    }
    Person.prototype.showName = function(){
        console.log('name:'+this.name+','+this.age);
    }
    return getInst;
})()
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市虎忌,隨后出現(xiàn)的幾起案子泡徙,更是在濱河造成了極大的恐慌,老刑警劉巖膜蠢,帶你破解...
    沈念sama閱讀 219,110評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件堪藐,死亡現(xiàn)場離奇詭異,居然都是意外死亡挑围,警方通過查閱死者的電腦和手機(jī)礁竞,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,443評論 3 395
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來杉辙,“玉大人模捂,你說我怎么就攤上這事≈┦福” “怎么了狂男?”我有些...
    開封第一講書人閱讀 165,474評論 0 356
  • 文/不壞的土叔 我叫張陵,是天一觀的道長品腹。 經(jīng)常有香客問我岖食,道長,這世上最難降的妖魔是什么舞吭? 我笑而不...
    開封第一講書人閱讀 58,881評論 1 295
  • 正文 為了忘掉前任泡垃,我火速辦了婚禮,結(jié)果婚禮上羡鸥,老公的妹妹穿的比我還像新娘蔑穴。我一直安慰自己,他們只是感情好兄春,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,902評論 6 392
  • 文/花漫 我一把揭開白布澎剥。 她就那樣靜靜地躺著锡溯,像睡著了一般赶舆。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上祭饭,一...
    開封第一講書人閱讀 51,698評論 1 305
  • 那天芜茵,我揣著相機(jī)與錄音,去河邊找鬼倡蝙。 笑死九串,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播猪钮,決...
    沈念sama閱讀 40,418評論 3 419
  • 文/蒼蘭香墨 我猛地睜開眼品山,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了烤低?” 一聲冷哼從身側(cè)響起肘交,我...
    開封第一講書人閱讀 39,332評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎扑馁,沒想到半個(gè)月后涯呻,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,796評論 1 316
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡腻要,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,968評論 3 337
  • 正文 我和宋清朗相戀三年复罐,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片雄家。...
    茶點(diǎn)故事閱讀 40,110評論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡效诅,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出咳短,到底是詐尸還是另有隱情填帽,我是刑警寧澤,帶...
    沈念sama閱讀 35,792評論 5 346
  • 正文 年R本政府宣布咙好,位于F島的核電站篡腌,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏勾效。R本人自食惡果不足惜嘹悼,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,455評論 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望层宫。 院中可真熱鬧杨伙,春花似錦、人聲如沸萌腿。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,003評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽毁菱。三九已至米死,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間贮庞,已是汗流浹背峦筒。 一陣腳步聲響...
    開封第一講書人閱讀 33,130評論 1 272
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留窗慎,地道東北人物喷。 一個(gè)月前我還...
    沈念sama閱讀 48,348評論 3 373
  • 正文 我出身青樓卤材,卻偏偏與公主長得像,于是被迫代替她去往敵國和親峦失。 傳聞我的和親對象是個(gè)殘疾皇子扇丛,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,047評論 2 355

推薦閱讀更多精彩內(nèi)容