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

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

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

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

步驟:

將函數(shù)設(shè)為對(duì)象的屬性; 指定this到函數(shù),并傳入給定參數(shù)執(zhí)行函數(shù); 執(zhí)行之后刪除這個(gè)函數(shù); 如果不傳入?yún)?shù),默認(rèn)指向window;

Function.prototype.mycall = function (context, ...args) { //判斷是否為函數(shù),如果不是函數(shù),則報(bào)錯(cuò) if (typeof this !== 'function') {throw new Error('不是函數(shù)'); } context = context || window; context.fn = this; const res = context.fn(...args); delete context.fn; return res;}

測(cè)試代碼:

var name = '李輝', age = 25;var obj = { name: '周果', objAge: this.age, myFun: function (fm, to) {console.log(`名字:${this.name},年齡:${this.age},來(lái)自:${fm},去往:${to}`) }};var person = { name: '弟弟', age: 12,};Function.prototype.mycall = function (context, ...args) { //判斷是否為函數(shù),如果不是函數(shù),則報(bào)錯(cuò) 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,來(lái)自:成都,去往:仁壽2、實(shí)現(xiàn)apply

Function.prototype.myApply = function (context, ...args) { //判斷是否為函數(shù),如果不是函數(shù),則報(bào)錯(cuò) 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;}

測(cè)試代碼:

obj.myFun.myApply(person, ['成都', '仁壽']); //名字:弟弟,年齡:12,來(lái)自:成都,去往:仁壽3、實(shí)現(xiàn)bind

bind()方法主要就是將函數(shù)綁定到某個(gè)對(duì)象,bind()會(huì)創(chuàng)建一個(gè)函數(shù),函數(shù)體內(nèi)的this對(duì)象的值會(huì)被綁定到傳入bind()中的第一個(gè)參數(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 () { //返回一個(gè)新的函數(shù)self.apply(context,[].concat.call(args,[...arguments])); }}

ES6簡(jiǎn)化一下:

Function.prototype.myBind = function (context, ...args1) {return (...args2) => { //返回箭頭函數(shù), this綁定調(diào)用這個(gè)方法的函數(shù)對(duì)象 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)用這個(gè)方法的函數(shù)對(duì)象context = context || window;context.fn = this;const args = args1.concat(args2);const res = context.fn(...args);delete context.fn;return res; }}

測(cè)試代碼:

obj.myFun.myBind(person, '成都', '仁壽')();//名字:弟弟,年齡:12,來(lái)自:成都,去往:仁壽

以上就是原生js如何實(shí)現(xiàn)call,apply以及bind的詳細(xì)內(nèi)容,更多關(guān)于js實(shí)現(xiàn)call,apply以及bind的資料請(qǐng)關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標(biāo)簽: JavaScript
主站蜘蛛池模板: 亚洲va久久久噜噜噜久久狠狠 | 美女张开腿让男人桶爽免 | 美女视频网站黄色 | 久青草青综合在线视频 | 亚洲福利精品一区二区三区 | 日韩久久久精品中文字幕 | 韩日黄色片 | 91网站在线免费观看 | 久久亚洲人成国产精品 | 免费一级毛片在线播放放视频 | 色爽爽爽爽爽爽爽爽 | 国产成人高清精品免费软件 | 男人的天堂欧美精品色偷偷 | 最新国产精品好看的国产精品 | 嫩草影院ncyy在线观看 | 中文字幕成人免费高清在线视频 | 99精品久久久久久久免费看蜜月 | 成人午夜看片 | 蝴蝶成人世界第八影院 | 日本二区免费一片黄2019 | 视频二区在线 | 51国产偷自视频区视频手机播器 | 国产精选莉莉私人影院 | 成人a毛片免费全部播放 | 91热久久免费频精品黑人99 | 国产在线91精品天天更新 | 99久久综合国产精品免费 | 日本特黄特色高清免费视频 | 欧美一级毛片欧美一级成人毛片 | 日韩美女视频在线观看 | 日本高清在线不卡 | 亚洲视频网址 | 亚洲视频手机在线 | 亚洲免费高清 | 一本一本久久a久久精品综合麻豆 | 欧美二级在线观看免费 | 最新国产美女肝交视频播放 | a级毛片无码免费真人 | 亚洲性xo| 精品欧美一区二区三区四区 | 欧美一区二区三区不卡片 |