av一区二区在线观看_亚洲男人的天堂网站_日韩亚洲视频_在线成人免费_欧美日韩精品免费观看视频_久草视

您的位置:首頁技術(shù)文章
文章詳情頁

原生js如何實(shí)現(xiàn)call,apply以及bind

瀏覽:138日期:2024-04-01 09:39:02
1、實(shí)現(xiàn)call

步驟:

將函數(shù)設(shè)為對象的屬性; 指定this到函數(shù),并傳入給定參數(shù)執(zhí)行函數(shù); 執(zhí)行之后刪除這個函數(shù); 如果不傳入?yún)?shù),默認(rèn)指向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、實(shí)現(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、實(shí)現(xiàn)bind

bind()方法主要就是將函數(shù)綁定到某個對象,bind()會創(chuàng)建一個函數(shù),函數(shù)體內(nèi)的this對象的值會被綁定到傳入bind()中的第一個參數(shù)的值。

方法1:使用apply

Function.prototype.myBind = function () { let self = this; //保存原函數(shù) let context = [].shift.call(arguments); //保存需要綁定的this上下文 let args = [...arguments]; //將傳入的剩余參數(shù)轉(zhuǎn)換成數(shù)組 return function () { //返回一個新的函數(shù)self.apply(context,[].concat.call(args,[...arguments])); }}

ES6簡化一下:

Function.prototype.myBind = function (context, ...args1) {return (...args2) => { //返回箭頭函數(shù), this綁定調(diào)用這個方法的函數(shù)對象 context = context || window; return this.apply(context, args1.concat(args2));//合并參數(shù)} }方法2:不使用call以及apply

將上面的代碼和js手寫實(shí)現(xiàn)apply的代碼合并一下:

Function.prototype.myBind = function (context, ...args1) { return (...args2) => { //返回箭頭函數(shù), this綁定調(diào)用這個方法的函數(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如何實(shí)現(xiàn)call,apply以及bind的詳細(xì)內(nèi)容,更多關(guān)于js實(shí)現(xiàn)call,apply以及bind的資料請關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標(biāo)簽: JavaScript
主站蜘蛛池模板: 国产电影一区二区 | 中文字幕一区二区三区乱码在线 | 午夜影院 | 亚洲一区视频在线 | 欧美国产精品一区二区三区 | 国产精品久久久久久妇女6080 | 国产精品免费高清 | 国产乱码精品一区二区三区忘忧草 | 久久久精品网 | 91在线视频在线观看 | 亚洲欧美视频一区 | 国产精品久久久久久久久久免费看 | 欧美性网| 91日日 | 亚洲区一区二 | 色女人天堂| 国产国语精品 | 精品欧美一区二区三区免费观看 | 久久久婷 | 一区二区三区中文 | 亚洲成人一区 | 女同久久 | 国产羞羞视频在线观看 | 中文字幕亚洲免费 | 视频一区在线观看 | 欧美群妇大交群中文字幕 | 欧美一区二区三区在线播放 | 久久国产美女视频 | 人人玩人人添人人澡欧美 | 久久免费国产视频 | 午夜影晥 | 欧美在线a | 超碰国产在线 | 一区二区福利视频 | 特黄级国产片 | 欧美精品一区二区免费视频 | 福利一区视频 | 欧美久久一区二区三区 | 欧美极品视频在线观看 | 亚洲精品久久嫩草网站秘色 | 亚洲一区二区免费看 |