您好,登錄后才能下訂單哦!
這篇文章給大家分享的是有關(guān)javascript中bind怎么用的內(nèi)容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。
javascript中bind方法用于創(chuàng)建一個新的函數(shù),其使用語法是“function.bind(thisArg[, arg1[, arg2[, ...]]])”,其中參數(shù)thisArg表示調(diào)用綁定函數(shù)時作為this參數(shù)傳遞給目標(biāo)函數(shù)的值。
本文操作環(huán)境:windows7系統(tǒng)、javascript1.8.5版、Dell G3電腦。
javascript中bind的用法是什么?
Function.prototype.bind()
bind() 方法創(chuàng)建一個新的函數(shù),在 bind() 被調(diào)用時,這個新函數(shù)的 this 被指定為 bind() 的第一個參數(shù),而其余參數(shù)將作為新函數(shù)的參數(shù),供調(diào)用時使用。
語法
function.bind(thisArg[, arg1[, arg2[, ...]]])
參數(shù)thisArg:
調(diào)用綁定函數(shù)時作為 this 參數(shù)傳遞給目標(biāo)函數(shù)的值。 如果使用new運算符構(gòu)造綁定函數(shù),則忽略該值。當(dāng)使用 bind 在 setTimeout 中創(chuàng)建一個函數(shù)(作為回調(diào)提供)時,作為 thisArg 傳遞的任何原始值都將轉(zhuǎn)換為 object。如果 bind 函數(shù)的參數(shù)列表為空,或者thisArg是null或undefined,執(zhí)行作用域的 this 將被視為新函數(shù)的 thisArg。
參數(shù)arg1, arg2, ...:
當(dāng)目標(biāo)函數(shù)被調(diào)用時,被預(yù)置入綁定函數(shù)的參數(shù)列表中的參數(shù)。
返回值:
返回一個原函數(shù)的拷貝,并擁有指定的 this 值和初始參數(shù)。
描述:
bind() 函數(shù)會創(chuàng)建一個新的綁定函數(shù)(bound function,BF)。綁定函數(shù)是一個 exotic function object(怪異函數(shù)對象,ECMAScript 2015 中的術(shù)語),它包裝了原函數(shù)對象。調(diào)用綁定函數(shù)通常會導(dǎo)致執(zhí)行包裝函數(shù)。
綁定函數(shù)具有以下內(nèi)部屬性:
[[BoundTargetFunction]] - 包裝的函數(shù)對象
[[BoundThis]] - 在調(diào)用包裝函數(shù)時始終作為 this 值傳遞的值。
[[BoundArguments]] - 列表,在對包裝函數(shù)做任何調(diào)用都會優(yōu)先用列表元素填充參數(shù)列表。
[[Call]] - 執(zhí)行與此對象關(guān)聯(lián)的代碼。通過函數(shù)調(diào)用表達式調(diào)用。內(nèi)部方法的參數(shù)是一個this值和一個包含通過調(diào)用表達式傳遞給函數(shù)的參數(shù)的列表。
當(dāng)調(diào)用綁定函數(shù)時,它調(diào)用 [[BoundTargetFunction]] 上的內(nèi)部方法 [[Call]],就像這樣 Call(boundThis, args)。其中,boundThis 是 [[BoundThis]],args 是 [[BoundArguments]] 加上通過函數(shù)調(diào)用傳入的參數(shù)列表。
綁定函數(shù)也可以使用 new 運算符構(gòu)造,它會表現(xiàn)為目標(biāo)函數(shù)已經(jīng)被構(gòu)建完畢了似的。提供的 this 值會被忽略,但前置參數(shù)仍會提供給模擬函數(shù)。
感謝各位的閱讀!關(guān)于“javascript中bind怎么用”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,讓大家可以學(xué)到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。