码迷,mamicode.com
首页 > 编程语言 > 详细

JavaScript中this关键字的指向问题

时间:2017-07-05 18:43:37      阅读:123      评论:0      收藏:0      [点我收藏+]

标签:rip   apply   cti   call   bsp   log   成员方法   ons   全局对象   

1、纯粹的函数调用,this就代表全局对象Global

var x = 1;
function test(){
    var x = ‘二哈‘;
    console.log(this.x);    //1
}
test();

2、作为对象的成员方法时,this代表这个对象

var x = ‘二哈‘;
function
test(){ console.log(this.x); //1 } var obj = { x: 1, fn: test } obj.fn();

3、作为构造函数调用,this代表new关键字生成的新对象

var x = ‘二哈‘;
function
test(){
  this.x = 1; } var obj = new test(); console.log(obj.x) //1

4、使用call()方法或者apply()时,此方法的第一个参数为改变后调用这个函数的对象,this指代第一个参数,参数为空时,默认调用全局对象

var x = 1;
function test(){
  console.log(this.x);
}
var obj = {
    x: ‘二哈‘,
    fn: test
};
obj.fn.apply();    //1       

 

JavaScript中this关键字的指向问题

标签:rip   apply   cti   call   bsp   log   成员方法   ons   全局对象   

原文地址:http://www.cnblogs.com/holly-w/p/7122856.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!