当前位置: 移动技术网 > IT编程>开发语言>JavaScript > javascript实现方法调用与方法触发小结

javascript实现方法调用与方法触发小结

2019年07月31日  | 移动技术网IT编程  | 我要评论

在js中,this关键字是一个比较让人有意思的东西,但是它的指向经常让初学者摸不着头脑。

  其实要理解这个关键字,需要理清两个问题——“方法的调用和方法的触发”

  下面先看一段代码

<!doctype html>
<html>
<head>
<meta charset="utf-8">
<title>function</title>
<script>
function showthis(){
  console.info(this);
}
  
function test1(){
  this.f=showthis;
}
function test2(){
  this.f=function(){
    showthis();
  }
}

showthis();//window
new test1().f();//test1  
new test2().f();//window
</script>
</head>
<body>
</body>
</html> 

  20行打印出window对象,这个很容易理解,但是21行打印出test1的实例对象,而22行却打印出window对象。查看test1和test2的构造,发现方法f最终都执行了showthis方法。但是showthis中的this指向却不同。这是因为test1中的f方法直接指向showthis,new test1().f()是以test1 的实例直接调用showthis方法,调用者是test1的实例。而new test2().f()是在test2的实例方法f中触发window对象的showthis方法,其中的this就是指向其调用者window而不是触发者test2的实例。

  至此可以发现。this指向的是调用者,而触发者只是推进调用者执行指定方法而已。

如对本文有疑问, 点击进行留言回复!!

相关文章:

验证码:
移动技术网