1.对于javascript中的this关键字,表示的是当前代码所处的对象。
var a={ get:function(){ this.val=12 } } console.log(a.val); a.get(); console.log(a.val);
a是一个对象,注意一点,get并不是一个对象(其实也不对,javascript中万物皆为对象,但这样比较容易理解和记忆),而是a的一个属性,根据对this的定义,this所处的代码的对象正是a,所以this代表a对象。
function my(){ this.name='迪迦' } console.log(new my().name);
再比如这个例子,my是一个函数,但也是一个对象,this所处的代码的对象就是new my()之后的对象。
再举一个更明显的例子:
var obj={}; obj.click=function(){ this.name='xx'; } obj.click() console.log(obj.name)
obj是一个对象,而click是obj的一个属性,this所处的代码的对象指向的是obj,所以this代表obj;
2.如果需要向一个setInterval或者settimeout的执行函数传值,一般有如下做法:
setInterval("myFun("+arg+")",1000)
这样会显得很乱,比较合适的方式是利用闭包:
function myFun(age){ setInterval(function(){ console.log(age); },1000) }; myFun(15);
之所以能够这么做就是利用了闭包的特性:内层函数可以访问外部函数的变量,即使外层函数已经终止。
3.尝试使用所有对象的constructor属性,可以发现,javascript中所有的对象(包括函数)的构造器都是Function函数,也就是说不管是预定义的Object、Array对象,还是你自
定义的function也好,他们都是由Function函数构造的,有一点除外,那就是如果一个对象是你自定义的对象,比如:
var obj=function (){ this.name='xx'; } console.log(new obj().constructor==obj)
那么这个构造函数就是自定义的obj,而不是Function函数。