手写apply

目录

前言

导语


前言

我是歌谣 歌谣的意志是永恒的 放弃很容易 但是坚持一定很酷

导语

apply使用

​编辑

代码部分

``` Function.prototype.myApply = function (context, args) { //这里默认不传就是给window,也可以用es6给参数设置默认参数 context = context || window args = args ? args : [] //给context新增一个独一无二的属性以免覆盖原有属性 const key = Symbol() context[key] = this //通过隐式绑定的方式调用函数 const result = contextkey //删除添加的属性 delete context[key] //返回函数调用的返回值 return result } var name = 'geyao' var fangfang = { name: 'fangfang',

fang: function () {
console.log(this.name)
},
fun: function () {
console.log(this,"this")
setTimeout(
function () {
this.fang()
}.myApply(this),
100
)
},
}
fangfang.fun() //fangfang

```

posted @   前端导师歌谣  阅读(4)  评论(0编辑  收藏  举报  
相关博文:
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
· AI与.NET技术实操系列(六):基于图像分类模型对图像进行分类
历史上的今天:
2022-08-05 Vuex学习3-Vuex的基本使用
2022-08-05 Vuex学习2-vuex概述
2022-08-05 Vuex学习1-vuex学习目标
2022-08-05 typescript87-react中状态和事件
2022-08-05 typescript86-react中类组件的类型
2022-08-05 typescript85-class组件类型
2022-08-05 typescript84-事件类型
点击右上角即可分享
微信分享提示