码迷,mamicode.com
首页 > 编程语言 > 详细

javascript学习笔记-3

时间:2015-06-19 23:06:11      阅读:142      评论:0      收藏:0      [点我收藏+]

标签:

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函数。

javascript学习笔记-3

标签:

原文地址:http://www.cnblogs.com/liaochong/p/javascript3.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!