轻易掌握this关键字

面向对象语言中 this 表示当前对象的一个引用. 但在 JavaScript 中 this 不是固定不变的,它会随着执行环境的改变而改变。

我们先来说说this指向的几种方式
  • 在方法中,this 则表示该方法所属的对象
var obj = {
  name1: "zhang",
  name2 : "wang",
  newName : function() {
    return this.name1 + " " + this.name2;
  }
};

// 显示对象的数据
document.getElementById("a1").innerHTML = obj.newName();

zhang wang
  • 单独使用,this 则表示全局对象

"use strict";
var aa = this;
// window 就是该全局对象为 [object Window]

  • 在函数中,this 则表示全局对象

function funciton() {
  return this;
}
// window 就是该全局对象为 [object Window]

window.function();
  • 在函数中,在严格模式下,this 是未定义的(undefined)
  • 在事件中,this 表示接收事件的元素
<button onclick="this.style.display='none'">
点我
</button>

再接着说改变this的几种方式
  • call()
格式 函数名.call();
参数: 
	第一个参数: 传入该函数this指向的对象,传入什么强制指向什么
	第二个参数开始:将原函数的参数往后顺延一位。
	
	函数名.call('call',1,2);
  • apply()
格式 函数名.apply();
参数: 
	第一个参数: 传入该函数this指向的对象,传入什么强制指向什么
	第二个参数: 数组 。数组里面放入我们原有的参数
	
	函数名.apply('a',[1,2])
  • bind() 预设this指向
var a = 函数名.bind('aa'); 先通过bind的预设下thie指向,然后返回一个新函数,此时这个新函数this已经指向bb了
a(1,2);
函数名.bind('指向的名字')('原来的参数')
简写 函数名.bind('aa')(1,2);  
总结this指向的四种方式

a.如果是一般函数,this指向全局对象window;
b.在严格模式下"use strict",为undefined.
c.对象的方法里调用,this指向调用该方法的对象.
d.构造函数里的this,指向创建出来的实例.

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值