call apply bind 修改this指向的区别

javascript 复制代码
  var obj1 = {
        name: 'zhang',
        getName() {
            console.log(this.name)
        }
    }
    var obj2 = {
        name: 'list',
        getName() {
            console.log(this.name)
        }
    }
    obj1.getName.call(obj2)  //list
    obj1.getName.apply(obj2)  //list
    obj1.getName.bind(obj2)  //  
    obj2.getName()           //list

call 改变this,自动执行函数,

apply 改变this,自动执行函数,第二个参数开始:将原函数的参数放在一个数组中

bind 改变this,手动加括号执行函数(),不会自动执行

相关推荐
dangdang___go6 分钟前
文件操作2+程序的编译和链接(1)
java·服务器·前端
西西学代码9 分钟前
Flutter中常用的UI设计
前端·flutter·ui
Sunhen_Qiletian11 分钟前
《Python开发之语言基础》第七集:库--时间库
前端·数据库·python
JokerLee...15 分钟前
【Vtable自定义样式】
前端·javascript·vtable
PyHaVolask20 分钟前
XSS跨站脚本攻击
前端·xss·web漏洞
K3v20 分钟前
【nvm安装14.x失败】nvm设置国内镜像源 npm设置全局缓存以及全局包目录
前端·缓存·npm
DsirNg39 分钟前
Vue 3 Keep-Alive 深度实践:从原理到最佳实践
前端
拾忆,想起42 分钟前
Dubbo序列化异常终结指南:从精准诊断到根治与防御
开发语言·前端·微服务·架构·php·dubbo·safari
不如摸鱼去1 小时前
uni-app 也能远程调试?使用 PageSpy 打开调试的新大门!
前端·小程序·uni-app
姓蔡小朋友1 小时前
Redis内存回收
前端·数据库·redis