JavaScript面向对象编程-封装

<!doctype html>
<html>
 <head>
  <title>Document</title>
  <script type="text/javascript" src="jquery-1.8.3.min.js"></script>
  <script>
	/*JavaScript面向对象编程-封装*/
	$(function(){
		// 生成对象的原始模式
		var Cat = {
			name : '',
			color : ''
		};

		var c1 = {};	// 创建一个空对象
		c1.name = '大毛';
		c1.colr = '黄色';

		var c2 = {};
		c2.name = '二毛';
		c2.color = '黑色';

	//	alert(c1.name);
	
		// 原始模式的改进
		function Cat(name, color){
			return {
				name : name,
				color : color
			}
		}
		
	//	var c3 = Cat('大毛', '黄色');
	//	var c4 = Cat('二毛', '黑色');
	//	alert(c4);

		// 构造函数模式
		function Person(name, gender) {
			this.name = name;
			this.gender = gender;
			// 内存浪费问题
			this.type = '人';
			this.eat = function(){
				alert('吃饭...');
			}
		}
		
		var c5 = new Person('张三', '男');
		var c6 = new Person('李四', '女');

	//	alert(c5.name + ',' + c5.gender);

	//	alert(c5.constructor == Person);
	//	alert(c6 instanceof Person);

		// Prototype模式
		function Dog(name, gender){
			this.name = name;
			this.gender = gender;
		}

		Dog.prototype.type = '狗';
		Dog.prototype.eat = function(){
			alert('狗是最忠实的动物!');
		}
		
		var dog1 = new Dog('大黄', '公');
		var dog2 = new Dog('二黄', '母');

	//	alert(dog1.type);
	//	alert(dog2.type);
	//	alert(dog1.type == dog2.type); // true

	//	dog1.eat();
	//	dog2.eat();

	//	alert(dog1.eat == dog2.eat); // true

	//	alert(Dog.prototype.isPrototypeOf(dog1));
		
		// 用来判断某一个属性到底是本地属性,还是继承自prototype对象的属性。
	//	alert(dog1.hasOwnProperty('name'));

		// in运算符
		// 判断某个实例是否含有某个属性
	//	alert('name' in dog1); // true

		// 用来遍历某个对象的所有属性
		for(var pro in dog1) {
			alert(pro);
		}

		var arrs = [1, 2, 3, 4];
		for(var i in arrs) {
			console.log(i);
		}

	});
  </script>
 </head>
 <body>
  
 </body>
</html></span>

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值