1.每個函數都包含兩個非繼承而來的方法:apply()和call()。
2、他們的用途相同,都是在特定的作用域中呼叫函數。
3.接收參數方面不同,apply()接收兩個參數,一個是函數運作的作用域(this),另一個是參數陣列。
call()方法第一個參數與apply()方法相同,但傳遞給函數的參數必須列舉出來。
例1:
程式碼如下:
window.lastName = "song";
var myObject = { firstName: "my", lastName: "Object" };
function HelloName() {
console.log("Hello " this.firstName " " this.lastName, " glad to meet you!");
}
HelloName.call(myObject );
運行結果為:
Hello diz song glad to meet you!
function sum(num1, num2) {
return numnum1 2 console.log(sum.call(window, 10, 10)); //20
console.log(sum.apply(window,[10,20])); //30
var myObject = { firstName: "my", lastName: "Object" };
function HelloName() {
console.log("Hello " this.firstName " " this.lastName, " glad to meet you!");
}
HelloName(); //Hello diz song glad to meet you!
myObject.HelloName = HelloName;
myObject. HelloName(); //Hello my Object glad to meet you!
見加紅的程式碼,我們發現,要想讓HelloName()函數的作用域在物件myObject上,我們需要動態建立myObject的HelloName屬性,此屬性作為指標指向HelloName()函數,這樣,當我們呼叫myObject.HelloName()時,函數內部的this變數就指向myObjecct,也就可以呼叫該物件的內部其他公共屬性了。
一個小問題:再看一看函數中定義函數時,this變數的狀況
function temp2() {
console.log(this); //Window
}
temp2();
}
var Obj = {};
temp1.call(Obj); //運行結果請見上面綠色的註解! ! ! !
執行結果與下面的相同:
複製程式碼
程式碼如下
function temp1() {
console.log(this);
temp2();
}
function temp2() {
console.log(this);
var Obj = {}; temp1.call(Obj);
4、bind()方法複製程式碼
程式碼如下:
window.color = " red";
var o = { color: "blue" };
function sayColor(){
alert(this.color);
var OSayColor = sayColor.bind(o ); OSayColor(); //blue 這裡,sayColor()呼叫bind()方法,並傳入o對象,回傳了OSayColor()函數,在OSayColor()中,this的值就為o對象。

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

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

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

JavaScript不需要安裝,因為它已內置於現代瀏覽器中。你只需文本編輯器和瀏覽器即可開始使用。 1)在瀏覽器環境中,通過標籤嵌入HTML文件中運行。 2)在Node.js環境中,下載並安裝Node.js後,通過命令行運行JavaScript文件。

如何在Quartz中提前發送任務通知在使用Quartz定時器進行任務調度時,任務的執行時間是由cron表達式設定的。現�...

在JavaScript中如何獲取原型鏈上函數的參數在JavaScript編程中,理解和操作原型鏈上的函數參數是常見且重要的任�...

在微信小程序web-view中使用Vue.js動態style位移失效的原因分析在使用Vue.js...

在Tampermonkey中如何對多個鏈接進行並發GET請求並依次判斷返回結果?在Tampermonkey腳本中,我們經常需要對多個鏈...


熱AI工具

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

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

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

SecLists
SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。

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

Dreamweaver CS6
視覺化網頁開發工具

Atom編輯器mac版下載
最受歡迎的的開源編輯器

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