js閉包實例匯總_基礎知識
Js閉包
閉包前要了解的知識
1. 函數作用域
(1).Js語言特殊之處在於函數內部可以直接讀取全域變數
如果在php裡
$n=100;
function parent(){
echo $n;
}
parent();//會報錯 n未定義
?>
(2).在函數外部無法讀取函數內的局部變數
注意函數內部宣告變數時一定要加var,否則就宣告了一個全域變數
function parent(){
m=50;
}
parent();
alert(m);//50
//當然在php裡更是如此了,
function parent(){
global $m;//全域 ,定義與賦值要分開
$m=50;
}
parent();
echo $m;//50
?>
//沒global的話,一樣會報沒定義的錯誤
有時,需要得到函數內部的的局部變量,就需要變通的方法實現利用js變量作用域的特點,如在函數內部定義子函數,對於子函數來說,父函數就是它的全局,子函數可以存取父函數裡的變數(對於整個js程式碼來說又是局部變數)
Parent內部所有局部變數對其子函數來說都是可見的,但其子函數內的局部變數對其父函數是不可見的,這就是js特有的鍊式作用域結構,子物件會一級一級地向上查找所有父對象的變數,父對象的所有變數對子對像都是可見的,反之不成立!上面的son函數就是閉包
有些同學可能這樣
function parent(){
var m=50;
function son(){
alert(m);
}
}
parent();
son()//會報 函數son未定義
注意 在javascript裡,在函數裡宣告的函數都是局部的,函數運行完後就釋放了
注意這點與php的差別
function parent(){
function son(){
$m=50;
echo $m;
}
}
parent();
son();//輸出50 不會報錯
?>
閉包
函數內部定義函數,連接函數內部和外部的橋樑
閉包的作用有2個:
一是前面提到的讀取函數內部的變量,
二是讓這些變數的值保存在記憶體中,實現資料共享
下面是幾個閉包的例子
把匿名函數的執行結果(即對裡面子函數的宣告賦給全域變數cut),i就保存在記憶體裡了
執行cut()時就直接從內存取值了,i只有cnt()函數才能調用,直接alert(i)是不行的
還可以向閉包內傳參
var cnt=(function(num){
return function(){
alert(num);
num ;
}
})(5);
cnt();//5
cnt();//6
cnt();//7
//當然還可以呼叫時傳參
var cnt=(function(){
var i=0;
return function(num){
num =i;
alert(num);
i ;
}
})();
cnt(1);//1
cnt(2);//3
cnt(3);//5
為了對閉包有更好的理解,我們看以下程式碼
例如我想回傳一個數組,數組裡面有5個函數,第一個函數彈出0,第二個彈出1...
程式碼如果這樣寫
function box(){
var arr=[];
for(i=0;i arr=function(){return i;}
}
return arr;
}
var a=box();
alert(a);//包含五個函數體的陣列
alert(a[0]());
alert(a[1]());
彈出的函數體
function(){return i;} }
最後這個i是4,之後 成為5
For循環停止
發現均彈出5,明顯不符合我們的要求
解1
自我即時執行裡面的函數
function box(){
var arr=[];
for(i=0;i arr=(function(num){return i;})(i);
}
return arr;
}
var a=box();
for(var i=0;i
}
但是我們發現 傳回的陣列裡的元素是函數執行的結果,但我們想要的是函數有得升級我們的程式碼
解2
閉包實現
function box(){
var arr=[];
for(var i=0;i
arr=(function(num){
return function(){return num;}
})(i);
}
return arr;
}
var arr=box();
for(var i=0;i
alert(arr());//0,1,2,3,4
}
關鍵程式碼
arr=(function(num){
return function(){return num;}
})(i);
i=0 時
arr[0]=(function(num){return function(){return num;}})(0);
1時
arr[1]=(function(num){return function(){return num;}})(1);
以上就是閉包的好處!非常簡單實用吧。

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

熱門話題

人臉偵測辨識技術已經是一個比較成熟且應用廣泛的技術。而目前最廣泛的網路應用語言非JS莫屬,在Web前端實現人臉偵測辨識相比後端的人臉辨識有優勢也有弱勢。優點包括減少網路互動、即時識別,大大縮短了使用者等待時間,提高了使用者體驗;弱勢是:受到模型大小限制,其中準確率也有限。如何在web端使用js實現人臉偵測呢?為了實現Web端人臉識別,需要熟悉相關的程式語言和技術,如JavaScript、HTML、CSS、WebRTC等。同時也需要掌握相關的電腦視覺和人工智慧技術。值得注意的是,由於Web端的計

在C++中,閉包是能夠存取外部變數的lambda表達式。若要建立閉包,請擷取lambda表達式中的外部變數。閉包提供可重複使用性、資訊隱藏和延遲求值等優點。它們在事件處理程序等實際情況中很有用,其中即使外部變數被銷毀,閉包仍然可以存取它們。

C++Lambda表達式支援閉包,即保存函數作用域變數並供函數存取。語法為[capture-list](parameters)->return-type{function-body}。 capture-list定義要捕獲的變量,可以使用[=]按值捕獲所有局部變量,[&]按引用捕獲所有局部變量,或[variable1,variable2,...]捕獲特定變量。 Lambda表達式只能存取捕獲的變量,但無法修改原始值。

閉包是一種巢狀函數,它能存取外層函數作用域的變量,優點包括資料封裝、狀態保持和靈活性。缺點包括記憶體消耗、效能影響和調試複雜性。此外,閉包還可以建立匿名函數,並將其作為回調或參數傳遞給其他函數。

函數指針和閉包對Go性能的影響如下:函數指針:稍慢於直接調用,但可提高可讀性和可復用性。閉包:通常更慢,但可封裝資料和行為。實戰案例:函數指標可最佳化排序演算法,閉包可建立事件處理程序,但會帶來效能損失。

js和vue的關係:1、JS作為Web開發基石;2、Vue.js作為前端框架的崛起;3、JS與Vue的互補關係;4、JS與Vue的實踐應用。

是的,可以透過鍊式呼叫和閉包優化程式碼簡潔性和可讀性:鍊式呼叫可將函數呼叫連結為一個流暢介面。閉包可建立可重複使用程式碼區塊,並在函數外部存取變數。

Java中的閉包允許內部函數存取外部的作用域變量,即使外部函數已經退出。透過匿名內部類別實現,內部類別持有一個外部類別的引用,使外部變數保持活動。閉包增強了程式碼靈活性,但需要注意記憶體洩漏風險,因為匿名內部類別對外部變數的參考會保持這些變數的活動狀態。
