色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁技術文章
文章詳情頁

原生js如何實現call,apply以及bind

瀏覽:139日期:2024-04-01 09:39:02
1、實現call

步驟:

將函數設為對象的屬性; 指定this到函數,并傳入給定參數執行函數; 執行之后刪除這個函數; 如果不傳入參數,默認指向window;

Function.prototype.mycall = function (context, ...args) { //判斷是否為函數,如果不是函數,則報錯 if (typeof this !== 'function') {throw new Error('不是函數'); } 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) { //判斷是否為函數,如果不是函數,則報錯 if (typeof this !== 'function') {throw new Error('不是函數'); } context = context || window; context.fn = this; const res = context.fn(...args); delete context.fn; return res;}obj.myFun.mycall(person, '成都', '仁壽'); //名字:弟弟,年齡:12,來自:成都,去往:仁壽2、實現apply

Function.prototype.myApply = function (context, ...args) { //判斷是否為函數,如果不是函數,則報錯 if (typeof this !== 'function') {throw new Error('不是函數'); } 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、實現bind

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

方法1:使用apply

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

ES6簡化一下:

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

將上面的代碼和js手寫實現apply的代碼合并一下:

Function.prototype.myBind = function (context, ...args1) { return (...args2) => { //返回箭頭函數, this綁定調用這個方法的函數對象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如何實現call,apply以及bind的詳細內容,更多關于js實現call,apply以及bind的資料請關注好吧啦網其它相關文章!

標簽: JavaScript
主站蜘蛛池模板: 91进入蜜桃臀在线播放 | 国产精品一区久久 | 一级做a爰性色毛片 | 91久久精品一区二区 | 欧美日韩亚洲国产 | 91日本在线视频 | 午夜a毛片| 亚洲一级成人 | 亚欧免费视频 | 日日狠狠久久偷偷四色综合免费 | 久久免费小视频 | 国产成人精品免费视频网页大全 | 精品日本一区二区三区在线观看 | 亚洲日本激情 | 婷婷亚洲久悠悠色在线播放 | 国产综合在线观看视频 | 亚洲高清一区二区三区四区 | 毛片视频在线免费观看 | 日韩精品免费一级视频 | 中文字幕av一区二区三区 | 在线欧美视频 | 香蕉tv亚洲专区在线观看 | chinese情侣真实自拍 | 国产成人亚洲综合一区 | 欧美国产日韩在线观看 | 精品欧美成人高清在线观看2021 | 亚洲一级毛片在线观播放 | 亚洲在线免费免费观看视频 | 欧美三级黄色 | 亚洲情a成黄在线观看动 | 精品亚洲永久免费精品 | 国产乱码精品一区二区三区四川人 | 国产三级国产精品 | 99久久精品男女性高爱 | 一级毛片在线视频 | 亚洲精品久久一区毛片 | 日本一级特黄特色大片免费视频 | 国产一区精品 | 国产成人综合网亚洲欧美在线 | 嫩草影院在线观看网站成人 | 大美女香蕉丽人视频网站 |