被讨论难了的this关键字

this关键字详解
本文详细解析了JavaScript中的this关键字,介绍了其绑定规则,包括默认绑定、隐形绑定、显性绑定及new绑定等,并通过实例展示了不同情况下this的具体用法。

this关键字

this是个常用的关键字,它被自动生成在函数作用域里.并代表函数执行环境的上下文.
如果在开发中,不了解this绑定在那个对象上,会很容易出现bug.

this绑定的规则

默认绑定

当函数独立使用,(没有对象属性的引用进行调用).
this会默认绑定在全局对象undefined.

var log = function () {
    console.log(this)
}
log() //window

使用严格模式
"use strict";
var log = function () {
    console.log(this)
}
log() //undefined

隐形绑定

当函数被某个对象的属性引用后调用.
this会绑定在该对象上.

var obj = {
    log: function () {
        console.log(this);
    }
}
obj.log() //obj

显性绑定

当函数调用时,指定函数的this绑定对象.
涉及的方法有callapplybind.

var log = function () {
    console.log(this)
}
var target = {}

var bindLog = log.bind(target)
bindLog() //target
log.call(target) //target
log.apply(target) //target
显性绑定的优先级比隐形绑定高
function log() {
    console.log(this.name)
}

var visibleObj = {
    name: 'visible'
}

var hideObj = {
    name: 'hide',
    log: log
}

hideObj.log.call(visibleObj) //visible

new绑定

当实例一个构造函数时.
构造函数的this会绑定在实例上.

function construct(tag) {
    this.tag = tag;
}

var instance = new construct('instance')
console.log(instance.tag) //instance
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值