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);
以上就是閉包的好處!非常簡單實用吧。

不同JavaScript引擎在解析和執行JavaScript代碼時,效果會有所不同,因為每個引擎的實現原理和優化策略各有差異。 1.詞法分析:將源碼轉換為詞法單元。 2.語法分析:生成抽象語法樹。 3.優化和編譯:通過JIT編譯器生成機器碼。 4.執行:運行機器碼。 V8引擎通過即時編譯和隱藏類優化,SpiderMonkey使用類型推斷系統,導致在相同代碼上的性能表現不同。

JavaScript在現實世界中的應用包括服務器端編程、移動應用開發和物聯網控制:1.通過Node.js實現服務器端編程,適用於高並發請求處理。 2.通過ReactNative進行移動應用開發,支持跨平台部署。 3.通過Johnny-Five庫用於物聯網設備控制,適用於硬件交互。

我使用您的日常技術工具構建了功能性的多租戶SaaS應用程序(一個Edtech應用程序),您可以做同樣的事情。 首先,什麼是多租戶SaaS應用程序? 多租戶SaaS應用程序可讓您從唱歌中為多個客戶提供服務

本文展示了與許可證確保的後端的前端集成,並使用Next.js構建功能性Edtech SaaS應用程序。 前端獲取用戶權限以控制UI的可見性並確保API要求遵守角色庫

JavaScript是現代Web開發的核心語言,因其多樣性和靈活性而廣泛應用。 1)前端開發:通過DOM操作和現代框架(如React、Vue.js、Angular)構建動態網頁和單頁面應用。 2)服務器端開發:Node.js利用非阻塞I/O模型處理高並發和實時應用。 3)移動和桌面應用開發:通過ReactNative和Electron實現跨平台開發,提高開發效率。

JavaScript的最新趨勢包括TypeScript的崛起、現代框架和庫的流行以及WebAssembly的應用。未來前景涵蓋更強大的類型系統、服務器端JavaScript的發展、人工智能和機器學習的擴展以及物聯網和邊緣計算的潛力。

JavaScript是現代Web開發的基石,它的主要功能包括事件驅動編程、動態內容生成和異步編程。 1)事件驅動編程允許網頁根據用戶操作動態變化。 2)動態內容生成使得頁面內容可以根據條件調整。 3)異步編程確保用戶界面不被阻塞。 JavaScript廣泛應用於網頁交互、單頁面應用和服務器端開發,極大地提升了用戶體驗和跨平台開發的靈活性。

Python更适合数据科学和机器学习,JavaScript更适合前端和全栈开发。1.Python以简洁语法和丰富库生态著称,适用于数据分析和Web开发。2.JavaScript是前端开发核心,Node.js支持服务器端编程,适用于全栈开发。


熱AI工具

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

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

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

MantisBT
Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。

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

MinGW - Minimalist GNU for Windows
這個專案正在遷移到osdn.net/projects/mingw的過程中,你可以繼續在那裡關注我們。 MinGW:GNU編譯器集合(GCC)的本機Windows移植版本,可自由分發的導入函式庫和用於建置本機Windows應用程式的頭檔;包括對MSVC執行時間的擴展,以支援C99功能。 MinGW的所有軟體都可以在64位元Windows平台上運作。

PhpStorm Mac 版本
最新(2018.2.1 )專業的PHP整合開發工具

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