JS中定义对象方式四: 使用原型(prototype)方式创建对象之二(弊端及其改进)

<html>

	<head>
		<script type="text/javascript">
	/*弊端:如果使用原型方式创建对象,那么生成的所有对象会共享原型中的属性,
	  这样一个对象改变了该属性也会反应到其他对象当中。代码如下:*/
			function Person()
			{}

			Person.prototype.username = new Array();
			Person.prototype.password = "0123";

			Person.prototype.getInfo = function()
			{
				alert(this.username + ":" + this.password);
			}
			
			var person = new Person();
			var person2 = new Person();

			person.username.push("zhangsan");
			person.username.push("lisi");
			person.password = "0000";
			
			person.getInfo();
			person2.getInfo();	
		


		</script>

	</head>

	<body>


	</body>


</html>
<html>

	<head>
		<script type="text/javascript">

			/*改进:
			  使用原型+构造函数方式来定义对象,对象之间的属性互不干扰
			  各个对象之间共享同一个方法。
			 */
			function Person()
			{
				this.username = new Array();
				this.password = "0123";
			}

			Person.prototype.getInfo = function()
			{
				alert(this.username + ":" + this.password);
			}
			
			var person = new Person();
			var person2 = new Person();

			person.username.push("zhangsan");
			person.password = "0000";

			person2.username.push("lisi");
			
			person.getInfo();
			person2.getInfo();	
		


		</script>

	</head>

	<body>


	</body>


</html>


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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值