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

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

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

瀏覽:102日期: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精品久久精品一区二区 | 91精品欧美成人 | 国产91九色刺激露脸对白 | 91香蕉成人 | 欧美激情成人网 | 97青草香蕉依人在线播放 | 日本巨乳中文字幕 | 四虎免费大片aⅴ入口 | 在线三级网址 | 大伊香蕉精品视频在线天堂 | 亚洲最大成人 | 国产福利最新手机在线观看 | 久久精品女人毛片国产 | 日韩永久在线观看免费视频 | 99久久亚洲 | 韩国福利影视一区二区三区 | 日韩中文字幕免费观看 | 亚洲九九 | 久久中文字幕综合不卡一二区 | 精品国产爱久久 | 亚洲国产午夜精品理论片的软件 | 日韩色网站| 国产欧美久久久另类精品 | a毛片成人免费全部播放 | 经典国产一级毛片 | 亚洲精品国产精品国自产 | 欧美做a一级视频免费观看 欧美做爱毛片 | 毛片视频网址 | 在线欧美一区 | 成人综合婷婷国产精品久久免费 | 亚洲第一欧美 | 色老头久久网 | 黄色一级片在线看 | 97精品国产高清在线看入口 | 久久久网站亚洲第一 |