console.log(this);在浏览器中打印出来的就是windows对象,没什么疑问
function test(){
var a = 1;
console.log(this.a);
}test()打印出的也是windows对象,因为test function 的上层对象是windows
var obj = {a: 1,b: function () {console.log(this);},c : {c1: 123,a: ‘xx‘,c2: function() {console.log(this);}}}obj.b(); //打印的是obj对象,因为obj.b的上层对象是objobj.c.c2(); //打印出的是obj.c对象,因为obj.c.c2的上层对象是obj.c
4.
var obj = {a: 1,b: function () {console.log(this);},c : {c1: 123,a: ‘xx‘,c2: function() {console.log(this);function test(){console.log(‘test‘,this);}test();}}}内部函数这种情况比较特殊,test function 的this指向全局,因为test在运行时才能执行,绑定的对象不可预测,丢失了上层对象一般来说,如果想获取上层对象,可以使用that的方式,var that = this.保存上层对象
var fn = function(){console.log(this)}.bind({a:1})fn();打印出来的this就是{a:1},注意,使用bind之后,apply/call方法就不能生效了
6.
原文:http://www.cnblogs.com/zhentaoo/p/6394680.html