闭包与非闭包
?
閉包函數(shù):閉包簡(jiǎn)單理解成"定義在一個(gè)函數(shù)內(nèi)部的函數(shù)"。
下面是一個(gè)標(biāo)準(zhǔn)的閉包函數(shù),內(nèi)部定義的函數(shù)可以讀取外部函數(shù)中定義的變量 ?,閉包函數(shù)須是在內(nèi)部定義的函數(shù),而不是在外部定義的。
var test = 10;var f = (function (){ var test = 20; return function (){ alert("訪問---"+test);//20} })();f();
?
變形1:
返回一個(gè)外部定義的函數(shù),并執(zhí)行這個(gè)外部函數(shù)foo
var test = 10;var f = (function (){ var test = 20;return foo; //10 })();f();function foo(){alert('foo1:'+test); //10}?
變形2:
這個(gè)其實(shí)已經(jīng)不是一個(gè)閉包,僅僅是一個(gè)函數(shù)調(diào)用,在自執(zhí)行的函數(shù)里,調(diào)用了另一個(gè)函數(shù)foo,而foo是在外部定義的,是無法讀取到內(nèi)部函數(shù)里定義的局部變量的,所以,foo()調(diào)用時(shí),讀取的是外部定義的全局變量10
var test = 10;(function (){ var test = 20;foo(); //10 })();function foo(){alert('foo1:'+test); //10}?
轉(zhuǎn)載于:https://www.cnblogs.com/lydialee/p/4869472.html
總結(jié)
- 上一篇: css3字体怎样设置阴影
- 下一篇: 3.集--LinkedTransferQ