国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發(fā) > JS > 正文

原生js代碼能實現(xiàn)call和bind嗎

2024-05-06 16:53:54
字體:
供稿:網(wǎng)友

js手動實現(xiàn)call和bind都是謊言

網(wǎng)上有很多關(guān)于說自己實現(xiàn)call和bind的原理的文章,然而call和bind的原理真如他們所說的那樣嗎?今天就讓我來推翻這些所謂的”原理“,揭開謊言下的真相。

首先看看網(wǎng)上對call的實現(xiàn):

// 手寫 callFunction.prototype.mycall = function (context) {  context = context || window;  context.fn = this;  const args = [...arguments].slice(1);  const result = context.fn(...args);  // 執(zhí)行fn時上下文context已被修改,不是我們所期望的call   delete context.fn;  return result;}function show() {  console.log(this);}show.mycall({haha:122});

以上代碼的執(zhí)行結(jié)果是

js代碼,call,bind

如你所見,這樣實現(xiàn)的call并不是我們所期望的那樣。

對比于函數(shù)自帶的call:

show.call({haha:122})

其結(jié)果為

js代碼,call,bind

分析其原因不難發(fā)現(xiàn),根據(jù)函數(shù)mycall,執(zhí)行context.fn(...args)之前修改了上下文context,所以執(zhí)行fn時所使用的上下文是修改后的上下文,導(dǎo)致與預(yù)期結(jié)果相差甚遠(yuǎn)。

核心

而且,往更深的層次去思考,call絕不是這樣(或類似這樣)實現(xiàn)的,call是底層語言為瀏覽器封裝好的函數(shù),是絕對不能也沒必要用js強行模仿的。

綜上,js模仿call和bind絕對沒有g(shù)et到底層原理,這樣的模仿只能用于娛樂而已,沒有實際價值。bind和call類似,這里就不贅述了。


注:相關(guān)教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 聂拉木县| 会昌县| 黄平县| 青浦区| 板桥市| 深州市| 贵溪市| 星座| 诸城市| 绥中县| 乐昌市| 江口县| 安康市| 临洮县| 江津市| 雷波县| 黔西县| 长垣县| 湛江市| 淮南市| 河西区| 揭西县| 吉林市| 龙州县| 河津市| 峨眉山市| 台中县| 浑源县| 汤原县| 临清市| 元朗区| 枣强县| 威信县| 延川县| 越西县| 隆化县| 宾阳县| 天全县| 共和县| 祁门县| 义马市|