javascript中模拟面向对象编程

<html>
	<head>
		<title>016</title>
		<script type="text/javascript" charset="utf-8">
			
			//面向对象
			//js并不是面向对象的语言,只能说去模拟
			/*
			var obj=new Object();//var obj={};
			obj.name='z3';
			obj.age='男';
			obj.sayName=function(){alert('我是张三');};
			
			obj.sayName();
			*/
			//类的概念
			//第一种类型,工厂模式
			/*
			function createPerson(name,sex,age){
				var obj=new Object();
				obj.name = name;
				obj.sex = sex;
				obj.age = age;
				obj.sayName=function(){alert("我是"+name);};
				return obj;
			}
			
			var p1 = createPerson('z3','男',20);
			var p2 = createPerson('l4','女',21);
			
			alert(p1.name);//z3
			alert(p1.sex);//男
			p1.sayName();//我是z3
			*/
			
			//第二种形式 构造函数 new Array new Date
			
			//函数的第一个字母大写(类的模板)
			function Person(name,age,sex){
				this.name=name;
				this.age=age;
				this.sex=sex;
				this.sayName=function(){alert(name);};
			}
			//构造一个对象 new关键字 传递模板代码 返回对象
			/*
			var p1=new Person('xiao 1',21,'男');
			var p2=new Person('xiao 2',22,'女');
			//alert(p1.name);//xiao 1
			//p2.sayName();//xiao 2
			
			alert(p1==p2);//false 类的概念,
			alert(p1.constructor==Person);//true
			alert(p2.constructor==Person);//true
			alert(p1 instanceof Person);//true
			alert(p1 instanceof Object);//true
			*/
			//创建对象的方法
			//1 创建构造函数
			var p1=new Person('xiao',20,'男');
			//2 作为普通函数去调用
			Person('xiao 2',20,'男');//调用者是windows,所以属性this指windows,所以属性是全局变量
			alert(name);//xiao 2
			//3 在另外一个对象的作用域中调用
			var o = new Object();
			//call apply
			Person.call(o,'xiao 4',10,'女');
			o.sayName();//xiao 4
				
		
		</script>
	</head>
	<body>
	
	</body>
</html>

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值