亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

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

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

瀏覽:90日期: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},來自:${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,來自:成都,去往:仁壽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,來自:成都,去往:仁壽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,來自:成都,去往:仁壽

以上就是原生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
主站蜘蛛池模板: 亚洲日韩aⅴ在线视频 | 成年片人免费www | 纯欧美一级毛片_免费 | 亚洲色图自拍 | 八十老妇xxxxx性开放 | 成人一区二区丝袜美腿 | www国产永久免费视频看看 | 午夜成年人视频 | 香蕉国产人午夜视频在线 | 青草视频国产 | 亚洲一区成人 | 狠狠色噜噜狠狠狠狠狠色综合久久 | 又爽又黄又无遮挡的激情视频免费 | 日韩大片免费观看视频播放 | 国产一级在线现免费观看 | 国产美女自拍视频 | 日本一区二区三区日本免费 | 小明永久视频免费播放 | 91香蕉国产在线观看人员 | 亚洲在线免费视频 | 中文字幕在线视频播放 | 久草在线精品视频 | 国内自拍经典三级在线 | 亚洲精品国产福利 | 一级黄色片免费的 | 精品自拍视频在线观看 | 在线观看日本免费视频大片 | 91视频综合 | 精品国产电影 | 国产成人精品1沈娜娜 | 在线毛片一区二区不卡视频 | 丁香月婷婷 | 亚洲天天做日日做天天看2018 | 18岁黄色 | 国内精自线一二区 | 欧美一级一一特黄 | 日本特交大片免费观看 | 国产精品天天看 | 国产九九在线 | 韩日中文字幕 | 久久青草免费91线频观看不卡 |