這篇文章將為大家詳細講解有關Javascript如何實現(xiàn)閉包,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

閉包
當內部函數(shù)被保存到外部時,將會生成閉包。閉包會導致原有作用域鏈不釋放,造成內存泄露
//內部的函數(shù)被返回到外部,必然形成閉包
function a(){
function b(){
var b = 234;
console.log(a);
}
var a = 123;
return b;
}
var demo = a();
demo(); // -->123function test1(){
var num = 100;
function test2(){
num ++;
console.log(num);
}
return test2;
}
var demo1 = test1();
demo1(); //101
demo1(); //102//
function test(){
var arr = [];
for(var i = 0; i < 10; i++){//當i = 10的時候循環(huán)停止
arr[i] = function(){ //arr的每一位都是一個函數(shù)
console.log(i);//雖然函數(shù)已經(jīng)定義,但未執(zhí)行
}
}
return arr;
}
var myArr = test();
for(var i = 0; i < myArr.length; i++ ){
myArr[i]();
}最后函數(shù)執(zhí)行的時候會調用test的AO中的i
AO{
i = 10;
}解決方案:立即執(zhí)行函數(shù)
function test() {
var arr = [];
for(var i = 0; i < 10; i++) {
(function(j) {
arr[j] = function() {
console.log(j);
}
}(i))
}
return arr;
}
var myArr = test();
for(var i = 0; i < myArr.length; i++) {
myArr[i]();
}1.實現(xiàn)公有變量
eg:函數(shù)累加器
function add(){
var count = 0;
function demo(){
count ++ ;
console.log(count);
}
return demo;
}
var counter = add();
counter();2.可以做緩存
eg:eater
function test2(){
var food = 'apple';
var obj = {
eatFood : function(){
if(food != ""){
console.log("I am eatting " + food);
food = '';
}else{
console.log("There is nothing! empty!");
}
},
pushFood : function(myFood){
food = myFood;
}
}
return obj;
}
var obj = test2();
obj.eatFood();
obj.eatFood();
obj.pushFood('banana');
obj.eatFood();3.可以實現(xiàn)封裝,屬性私有化。
eg: Person();
關于Javascript如何實現(xiàn)閉包就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
分享文章:Javascript如何實現(xiàn)閉包-創(chuàng)新互聯(lián)
鏈接URL:http://www.chinadenli.net/article22/deijcc.html
成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站改版、Google、定制開發(fā)、網(wǎng)站維護、營銷型網(wǎng)站建設、網(wǎng)頁設計公司
聲明:本網(wǎng)站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經(jīng)允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內容