note(1)

构造函数在不返回值的情况下,默认会返回新对象实例。而通过构造函数的末尾添加一个return语句,可以重写调用构造函数时的返回值

情况1:函数中有return语句,弹出name ,age

script type="text/javascript"> 
	  function Person(name, age, job){
	    var sex= 'M';  //name只是一个局部变量
		var person = new Object();
		person.name = '高伟刚';
		person.age = 23;
		/*构造函数在不返回值的情况下,默认会返回新对象实例。而通过构造函数的末尾添加一个return语句,可以重写调用构造函数时的返回值*/
		return person;
	  }
	  //1.创建一个新对象
	  //2.将构造函数的作用域赋给新对象(因此this就指向这个新对象)
	  //3.执行构造函数中的代码为这个新对象添加属性
	  //4.返回新对象
	  var person1 = new Person();
	  for(var prop in person1){
	    alert(prop); //name, age
	  }
	</script>

 

 

情况2:函数中没有return语句

 

<script type="text/javascript"> 
	  function Person(name, age, job){
	    var sex = 'M';  //name只是一个局部变量,如果要使sex成为全局变量,可以省略var
		this.job = 'Software Engineer';
		var person = new Object();
		person.name = '高伟刚';
		person.age = 23;
		/*构造函数在不返回值的情况下,默认会返回新对象实例。而通过构造函数的末尾添加一个return语句,
		  可以重写调用构造函数时的返回值*/
		//return person;
	  }
	  //1.创建一个新对象
	  //2.将构造函数的作用域赋给新对象(因此this就指向这个新对象)
	  //3.执行构造函数中的代码为这个新对象添加属性
	  //4.返回新对象
	  var person1 = new Person();
	  for(var prop in person1){
	    alert(prop); //job
	  }
	</script>

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值