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

Javascript中构造函数的返回值问题和new对象的过程

时间:2015-06-12 00:25:38      阅读:132      评论:0      收藏:0      [点我收藏+]

标签:

首先明确一点:javascript中构造函数是不需要有返回值的,这一点跟java很类似。可以认为构造函数和普通函数的最大差别就是:构造函数中没有return语句,普通函数可以有return语句;构造函数中会使用this关键字定义成员变量和成员方法,普通的函数不会使用this关键字定义成员变量和方法。

function Person(name,sex)
{
this.name = name;
this.sex = sex;
// return 1;
//return true;
//return "aty";
return {"returnValue":11};
}

//new关键字会被认为是创建对象
var aObj = new Person("11",1);
console.log(aObj.returnValue); //11
console.log(aObj.name); //undefined

  

 function Person(name,sex) 
		{  
		        this.name = name;
			this.sex = sex;
  			 return 1;
    			//return true;
    			//return "aty";
    			//return {"returnValue":11};
		}
 
		//new关键字会被认为是创建对象
		var aObj = new Person("11",1);
		console.log(aObj.returnValue); //undefined
		console.log(aObj.name); //11

  

构造函数不需要显示的返回值。使用new来创建对象(调用构造函数)时,如果return的是非对象(数字、字符串、布尔类型等)会忽而略返回值;如果return的是对象,则返回该对象。

下面简单介绍下,javascript中new对象的过程:如var myObj = newPerson(“aty”,25);

1.创建一个空的Object对象.var obj = new Object();

2.将构造函数Person中this指向刚创建的obj对象

3.将创建的obj的__proto__指向构造函数Person的prototype。这一步是建立对象和原型直接的对应关系。firefox下通过

对象的__proto__属性能够访问到原型,IE下则没有暴露出相应的属性。

4.执行构造函数Person()中的代码

Javascript中构造函数的返回值问题和new对象的过程

标签:

原文地址:http://www.cnblogs.com/huaan011/p/4570384.html

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