关于考察函数中输出调用的this的集中情况。
方法或者函数是由谁调用的,方法或者函数内部的this就指向谁(该对象)
注意:被谁调用,不是处于谁的作用域中,即使在作用域中不是它调用的,this也不是该作用域。
1.func是由myObject调用,所以this指向myObject。
2.self是this的副本,所以指向myObject。
3.这个下面的立即执行函数是由window调用的,所以this指向window。
4.这个IIFE的作用域在myObject.func的作用域中,此作用域中找不到self变量,沿着作用域链向上查找self变量,找到指向myObject的self。
*****************************************************************************************
js里面没有函数重载的概念,在java中可以存在同名函数,只要传入的参数不同就行,在js中,定义了两个同名函数后,后面的函数会覆盖前面定义的函数。也就存在函数声明提升,即函数声明会提前,如:
<script>
var m = 1,j = k = 0;
function add(n){
return n = n+1;
}
y = add(m);
function add(n){
return n = n+3;
}
z = add(m);
</script>
这个例子中后面的add覆盖了前面的,所以两次输出都为4。
本文探讨了JavaScript中this关键字的指向规则及函数的一些特殊性质,包括由谁调用this就指向谁的原则,并通过实例说明了函数声明提升及函数覆盖的现象。
3393

被折叠的 条评论
为什么被折叠?



