国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

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

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

瀏覽:134日期: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
主站蜘蛛池模板: 亚洲欧美在线免费 | 日本高清专区一区二无线 | 免费看一级欧美毛片视频 | 国产a级特黄的片子视频免费 | 99热99操99射| 欧美成人性做爰网站免费 | 九九精品视频在线播放8 | 七七国产福利在线二区 | 欧美一级视频在线高清观看 | 欧美日韩色黄大片在线视频 | 一级a俄罗斯毛片免费 | selaoban在线视频免费精品 | 欧美另类亚洲一区二区 | 欧美一级看片a免费观看 | 可以看毛片的网站 | 欧美日韩高清不卡免费观看 | 美女黄色在线看 | 亚洲韩国欧美一区二区三区 | 成人午夜天 | 国产午夜亚洲精品 | 福利三区 | 香蕉国产人午夜视频在线 | 成年人在线观看免费 | 亚洲精品xxx | 中国女警察一级毛片视频 | 日日a.v拍夜夜添久久免费 | 日韩欧美不卡一区二区三区 | 高清色黄毛片一级毛片 | 丝袜紧身裙国产在线播放 | 97se狠狠狠狠狠亚洲综合网 | 国产精品久久一区一区 | 色www永久免费网站国产 | 亚洲视频一区二区在线观看 | 亚洲视频在线免费 | 中文国产成人精品久久无广告 | 久久九九精品一区二区 | 99在线精品免费视频九九视 | 亚洲欧美国产精品专区久久 | a站在线观看 | 男人在线天堂 | 欧美一级看片免费观看视频在线 |