JavaScript中的bind方法的程式碼範例
Mar 11, 2019 pm 04:27 PM
javascript
這篇文章帶給大家的內容是關於JavaScript中的bind方法的程式碼範例,有一定的參考價值,有需要的朋友可以參考一下,希望對你有幫助。
之前已經實作過了call,apply和new。今天順便把bind也實現下。
首先:
- bind方法傳回的是一個綁定this後的函數,且該函數並沒有執行,需要手動去呼叫。 (從這點看bind函數就是一個高階函數,而且和call,apply方法有差別)。
- bind方法可以綁定this,傳遞參數。注意,這個參數可以分成多次傳遞。
- 如果bind綁定後的函數被new了,那麼此時this指向就改變。此時的this就是當前函數的實例。
- 建構子上的屬性和方法,每個實例上都有。
ok,上碼~
Function.prototype.mybind = function(context){ let that = this; let args1 = Array.prototype.slice.call(arguments,1); let bindFn = function(){ let args2 = Array.prototype.slice.call(arguments); return that.apply(this instanceof bindFn?this:context,args1.concat(args2)); } let Fn = function(){}; Fn.prototype = this.prototype; bindFn.prototype = new Fn(); return bindFn; }
登入後複製
首先 取得到第一次傳遞的參數args1,此處要做截取處理,因為第一個參數是this。接下來宣告一個函數bindFn,在該bindFn中取得了第二次傳的參數args2,並且傳回了that的執行。此處的that是原函數,執行該原函數綁定原函數this的時候要注意判斷。如果this是建構函數bindFn new出來的實例,那麼此處的this一定是該實例本身。反之,則是bind方法傳遞的this(context)。最後再把兩次得到的參數透過concat()連結起來傳遞進去,這樣就實現了前3條。
最後一條:建構函式上的屬性和方法,每個實例上都有。此處透過一個中間函數Fn,來連接原型鏈。 Fn的prototype等於this的prototype。 Fn和this指向同一個原型物件。 bindFn的prototype又等於Fn的實例。 Fn的實例的__proto__又指向Fn的prototype。即bindFn的prototype指向和this的prototype一樣,指向同一個原型物件。至此,就實現了自己的bind方法。
程式碼寫好了,測試一下~
Function.prototype.mybind = function(context){ let that = this; let args1 = Array.prototype.slice.call(arguments,1); let bindFn = function(){ let args2 = Array.prototype.slice.call(arguments); return that.apply(this instanceof bindFn?this:context,args1.concat(args2)); } let Fn = function(){}; Fn.prototype = this.prototype; bindFn.prototype = new Fn(); return bindFn; } let obj = { name:'tiger' } function fn(name,age){ this.say = '汪汪~'; console.log(this); console.log(this.name '養了一隻' name ',' age '歲了 '); } /** 第一次傳參 */ let bindFn = fn.mybind(obj,'
登入後複製
以上是JavaScript中的bind方法的程式碼範例的詳細內容。更多資訊請關注PHP中文網其他相關文章!
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱門文章
兩個點博物館:邦格荒地地點指南
4 週前
By 尊渡假赌尊渡假赌尊渡假赌
擊敗分裂小說需要多長時間?
3 週前
By DDD
倉庫:如何復興隊友
3 週前
By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
3 週前
By 尊渡假赌尊渡假赌尊渡假赌
公眾號網頁更新緩存難題:如何避免版本更新後舊緩存影響用戶體驗?
3 週前
By 王林

熱門文章
兩個點博物館:邦格荒地地點指南
4 週前
By 尊渡假赌尊渡假赌尊渡假赌
擊敗分裂小說需要多長時間?
3 週前
By DDD
倉庫:如何復興隊友
3 週前
By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
3 週前
By 尊渡假赌尊渡假赌尊渡假赌
公眾號網頁更新緩存難題:如何避免版本更新後舊緩存影響用戶體驗?
3 週前
By 王林

熱門文章標籤

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

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

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

Dreamweaver CS6
視覺化網頁開發工具

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