摘要:指定的參數列表語法在函數運行時指定的值。需要注意的是,指定的值并不一定是該函數執行時真正的值,如果這個函數處于非嚴格模式下,則指定為或時會自動指向全局對象瀏覽器中就是對象,同時值為原始值數字,字符串,布爾值的會指向該原始值的自動包裝對象。
我們都知道call apply bind都可以改變函數調用的this指向。那么它們三者有什么區別,什么時候該用哪個呢?
我們先直接通過代碼實例來了解,后面再借助專業文檔來解釋。
// 有只貓叫小黑,小黑會吃魚 const cat = { name: "小黑", eatFish(...args) { console.log("this指向=>", this); console.log("...args", args); console.log(this.name + "吃魚"); }, } // 有只狗叫大毛,大毛會吃骨頭 const dog = { name: "大毛", eatBone(...args) { console.log("this指向=>", this); console.log("...args", args); console.log(this.name + "吃骨頭"); }, } console.log("=================== call ========================="); // 有一天大毛想吃魚了,可是它不知道怎么吃。怎么辦?小黑說我吃的時候喂你吃 cat.eatFish.call(dog, "汪汪汪", "call") // 大毛為了表示感謝,決定下次吃骨頭的時候也喂小黑吃 dog.eatBone.call(cat, "喵喵喵", "call") console.log("=================== apply ========================="); cat.eatFish.apply(dog, ["汪汪汪", "apply"]) dog.eatBone.apply(cat, ["喵喵喵", "apply"]) console.log("=================== bind ========================="); // 有一天他們覺得每次吃的時候再喂太麻煩了。干脆直接教對方怎么吃 const test1 = cat.eatFish.bind(dog, "汪汪汪", "bind") const test2 = dog.eatBone.bind(cat, "喵喵喵", "bind") test1() test2()好了例子很簡單但是基本的使用方法跟場景都涉及到了。
call跟apply的用法幾乎一樣,唯一的不同就是傳遞的參數不同,call只能一個參數一個參數的傳入。
apply則只支持傳入一個數組,哪怕是一個參數也要是數組形式。最終調用函數時候這個數組會拆成一個個參數分別傳入。
至于bind方法,他是直接改變這個函數的this指向并且返回一個新的函數,之后再次調用這個函數的時候this都是指向bind綁定的第一個參數。bind傳餐方式跟call方法一致。
// 如果一個數組我們已知里面全都是數字,想要知道最大的那個數,由于Array沒有max方法,Math對象上有 // 我們可以根據apply傳遞參數的特性將這個數組當成參數傳入 // 最終Math.max函數調用的時候會將apply的數組里面的參數一個一個傳入,恰好符合Math.max的參數傳遞方式 // 這樣變相的實現了數組的max方法。min方法也同理 const arr = [1,2,3,4,5,6] const max = Math.max.apply(null, arr) console.log(max) // 6這里bind函數也有一個小技巧
// 如果你想將某個函數綁定新的`this`指向并且固定先傳入幾個變量可以在綁定的時候就傳入,之后調用新函數傳入的參數都會排在之后 const obj = {} function test(...args) {console.log(args)} const newFn = test.bind(obj, "靜態參數1", "靜態參數2") newFn("動態參數3", "動態參數4")接著來看看MDN文檔 call語法
fun.call(thisArg, arg1, arg2, ...)
thisArg: 在fun函數運行時指定的this值。需要注意的是,指定的this值并不一定是該函數執行時真正的this值,如果這個函數處于非嚴格模式下,則指定為null和undefined的this值會自動指向全局對象(瀏覽器中就是window對象),同時值為原始值(數字,字符串,布爾值)的this會指向該原始值的自動包裝對象。
arg1, arg2, ... 指定的參數列表
apply語法fun.apply(thisArg, [argsArray])
thisArg 在 fun 函數運行時指定的 this 值。需要注意的是,指定的 this 值并不一定是該函數執行時真正的 this 值,如果這個函數處于非嚴格模式下,則指定為 null 或 undefined 時會自動指向全局對象(瀏覽器中就是window對象),同時值為原始值(數字,字符串,布爾值)的 this 會指向該原始值的自動包裝對象。
argsArray 一個數組或者類數組對象,其中的數組元素將作為多帶帶的參數傳給 fun 函數。如果該參數的值為null 或 undefined,則表示不需要傳入任何參數。從ECMAScript 5 開始可以使用類數組對象。
bind語法fun.bind(thisArg[, arg1[, arg2[, ...]]])
thisArg 當綁定函數被調用時,該參數會作為原函數運行時的 this 指向。當使用new 操作符調用綁定函數時,該參數無效。
arg1, arg2, ... 當綁定函數被調用時,這些參數將置于實參之前傳遞給被綁定的方法。
總結當我們使用一個函數需要改變this指向的時候才會用到call`apply`bind
如果你要傳遞的參數不多,則可以使用fn.call(thisObj, arg1, arg2 ...)
如果你要傳遞的參數很多,則可以用數組將參數整理好調用fn.apply(thisObj, [arg1, arg2 ...])
如果你想生成一個新的函數長期綁定某個函數給某個對象使用,則可以使用const newFn = fn.bind(thisObj); newFn(arg1, arg2...)
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/90774.html
摘要:概括地講,如果構造函數有返回值,且返回值是對象不能是,那么對其進行操作返回該對象,否則返回構造實例。所以在方法中,我們需要進一步判斷這個構造函數有沒有返回值,返回值是不是對象。 自從進入七月以來,我的 underscore 源碼解讀系列 更新緩慢,再這樣下去,今年更完的目標似乎要落空,趕緊寫一篇壓壓驚。 前文 跟大家簡單介紹了下 ES5 中的 bind 方法以及使用場景(沒讀過的同學建...
摘要:最近面試幾家前端職位,想知道目前的前端面試題是偏向哪一塊,都主要問到的是語法,閉包,原型鏈,繼承那一塊。并且將面試題的知識點匯總一下。參考網站面試題圖片過多的時候如何優化圖標很多的時候可以用雪碧圖圖片過大時候可以壓縮一下。 最近面試幾家前端職位,想知道目前的前端面試題是偏向哪一塊,都主要問到的是ES6語法,閉包,原型鏈,繼承那一塊。并且將面試題的知識點匯總一下。有助于下次面試。 1.H...
摘要:閉包與柯里化閉包有權訪問另一個函數作用域中變量的函數。柯里化把接受多個參數的函數變換成接受一個單一參數最初函數的第一個參數的函數,并且返回接受余下的參數而且返回結果的新函數的技術。 本回內容介紹 上一回聊到JS的Object類型,簡單模擬了一下Java的Map,介一講,偶們來聊一下函數好唔好,介可系JS世界的一等公民喲。從函數開始,我們就將逐步過渡到設計模式,來吧,帥狐帶你裝逼帶你飛:...
閱讀 3725·2021-11-17 09:33
閱讀 2750·2021-09-22 15:12
閱讀 3354·2021-08-12 13:24
閱讀 2451·2019-08-30 11:14
閱讀 1740·2019-08-29 14:09
閱讀 1331·2019-08-26 14:01
閱讀 3070·2019-08-26 13:49
閱讀 1785·2019-08-26 12:16