欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

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

程序员文章站 2022-06-20 20:11:14
在js中,this关键字是一个比较让人有意思的东西,但是它的指向经常让初学者摸不着头脑。   其实要理解这个关键字,需要理清两个问题——“方法的调用和方法的触发”   ...

在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指向的是调用者,而触发者只是推进调用者执行指定方法而已。