Angular.JS中的this指向详解
【this详解】
1、谁最终调用函数,this指向谁。
①this指向的,永远只可能是对象!!!!!!
②this指向谁,永远不取决于this写在哪!!而是取决于函数在哪调用。
③this指向的对象,我们称之为函数的上下文context,也叫函数的调用者
2、※※※※※this指向的规律(与函数调用的方式息息相关):
this指向的情况,取决于函数调用的方式有哪些:
①通过函数名()直接调用:this指向window
②通过对象.函数名()调用的:this指向这个对象
③函数作为数组的一个元素,通过数组下标调用的:this指向这个数组
④函数作为window内置函数的回调函数调用:this指向windowsetInterval setTimeout等...
⑤函数作为构造函数,用new关键字调用时:this指向新new出的对象
functionfunc(){ console.log(this); }
①通过函数名()直接调用:this指向window
func();this--->window
②通过对象.函数名()调用的:this指向这个对象
狭义对象
varobj={ name:"obj", func1:func }; obj.func1();this--->obj
广义对象
document.getElementById("div").onclick=function(){ this.style.backgroundColor="red"; };this--->div
③函数作为数组的一个元素,通过数组下标调用的:this指向这个数组
vararr=[func,1,2,3]; arr[0]();this--->arr
④函数作为window内置函数的回调函数调用:this指向window
setTimeout(func,1000);//this--->window setInterval(func,1000);
⑤函数作为构造函数,用new关键字调用时:this指向新new出的对象
varobj=newfunc();//this--->new出的新obj
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对毛票票的支持。