原生js如何實現(xiàn)call,apply以及bind
1、實現(xiàn)call
步驟:
- 將函數(shù)設為對象的屬性;
- 指定this到函數(shù),并傳入給定參數(shù)執(zhí)行函數(shù);
- 執(zhí)行之后刪除這個函數(shù);
- 如果不傳入?yún)?shù),默認指向window;
Function.prototype.mycall = function (context, ...args) { //判斷是否為函數(shù),如果不是函數(shù),則報錯 if (typeof this !== "function") { throw new Error("不是函數(shù)"); } context = context || window; context.fn = this; const res = context.fn(...args); delete context.fn; return res; }
測試代碼:
var name = "李輝", age = 25; var obj = { name: "周果", objAge: this.age, myFun: function (fm, to) { console.log(`名字:${this.name},年齡:${this.age},來自:${fm},去往:${to}`) } }; var person = { name: "弟弟", age: 12, }; Function.prototype.mycall = function (context, ...args) { //判斷是否為函數(shù),如果不是函數(shù),則報錯 if (typeof this !== "function") { throw new Error("不是函數(shù)"); } context = context || window; context.fn = this; const res = context.fn(...args); delete context.fn; return res; } obj.myFun.mycall(person, "成都", "仁壽"); //名字:弟弟,年齡:12,來自:成都,去往:仁壽
2、實現(xiàn)apply
Function.prototype.myApply = function (context, ...args) { //判斷是否為函數(shù),如果不是函數(shù),則報錯 if (typeof this !== "function") { throw new Error("不是函數(shù)"); } context = context || window; context.fn = this; args = args && args[0] || []; const result = context.fn(...args); delete context.fn; return result; }
測試代碼:
obj.myFun.myApply(person, ["成都", "仁壽"]); //名字:弟弟,年齡:12,來自:成都,去往:仁壽
3、實現(xiàn)bind
bind()方法主要就是將函數(shù)綁定到某個對象,bind()會創(chuàng)建一個函數(shù),函數(shù)體內的this對象的值會被綁定到傳入bind()中的第一個參數(shù)的值。
方法1:使用apply
Function.prototype.myBind = function () { let self = this; //保存原函數(shù) let context = [].shift.call(arguments); //保存需要綁定的this上下文 let args = [...arguments]; //將傳入的剩余參數(shù)轉換成數(shù)組 return function () { //返回一個新的函數(shù) self.apply(context,[].concat.call(args,[...arguments])); } }
ES6簡化一下:
Function.prototype.myBind = function (context, ...args1) { return (...args2) => { //返回箭頭函數(shù), this綁定調用這個方法的函數(shù)對象 context = context || window; return this.apply(context, args1.concat(args2));//合并參數(shù) } }
方法2:不使用call以及apply
將上面的代碼和js手寫實現(xiàn)apply的代碼合并一下:
Function.prototype.myBind = function (context, ...args1) { return (...args2) => { //返回箭頭函數(shù), this綁定調用這個方法的函數(shù)對象 context = context || window; context.fn = this; const args = args1.concat(args2); const res = context.fn(...args); delete context.fn; return res; } }
測試代碼:
obj.myFun.myBind(person, "成都", "仁壽")();//名字:弟弟,年齡:12,來自:成都,去往:仁壽
以上就是原生js如何實現(xiàn)call,apply以及bind的詳細內容,更多關于js實現(xiàn)call,apply以及bind的資料請關注腳本之家其它相關文章!
相關文章
JavaScript中的函數(shù)申明、函數(shù)表達式、箭頭函數(shù)
js中的函數(shù)可以通過幾種方式創(chuàng)建,具體創(chuàng)建方法通過實例代碼給大家介紹的非常詳細,文中通過例子給大家介紹了函數(shù)聲明和表達式之間的差別,感興趣的朋友跟隨小編一起看看吧2019-12-12javascript實現(xiàn)數(shù)字倒計時特效
這篇文章主要介紹了javascript實現(xiàn)網頁倒計時數(shù)字時鐘效果,是一款非常實用的javascript倒計時特效,具有一定參考借鑒價值,需要的朋友可以參考下2016-03-03JavaScript獲取圖片像素顏色并轉換為box-shadow顯示
這篇文章主要介紹了JavaScript獲取圖片像素顏色并轉換為box-shadow顯示的方法,用到了HTML5中的FileReader API和getImageData,轉換為的CSS3 box-shadow也要注意瀏覽器的兼容問題,需要的朋友可以參考下2016-03-03JS賦值、淺拷貝和深拷貝(數(shù)組和對象的深淺拷貝)實例詳解
這篇文章主要介紹了JS賦值、淺拷貝和深拷貝,結合實例形式總結分析了JavaScript數(shù)組和對象的深淺拷貝相關概念、原理、操作技巧與使用注意事項,需要的朋友可以參考下2020-03-03JavaScript是如何實現(xiàn)繼承的(六種方式)
大多OO語言都支持兩種繼承方式: 接口繼承和實現(xiàn)繼承 ,而ECMAScript中無法實現(xiàn)接口繼承,ECMAScript只支持實現(xiàn)繼承,而且其實現(xiàn)繼承主要是依靠原型鏈來實現(xiàn),下文給大家技術js實現(xiàn)繼承的六種方式,需要的朋友參考下2016-03-03