《Javascript权威指南》学习笔记之七:面向对象编程(OOP)

一、Javascript中“类”的定义方式

1、

[javascript] view plain copy print ? 在CODE上查看代码片 派生到我的代码片
  1. function Person(name,age) 
  2. this.age=age; 
  3. this.name=name; 
  4. this.show=function() 
  5.     return ("my name is "+this.name+",and my age is "+this.age); 
  6. var per = new Person("yuan",20); 
  7. alert(per.show()); 
function Person(name,age)
{
this.age=age;
this.name=name;
this.show=function()
{
	return ("my name is "+this.name+",and my age is "+this.age);
}
}
var per = new Person("yuan",20);
alert(per.show());

2、

[javascript] view plain copy print ? 在CODE上查看代码片 派生到我的代码片
  1. function Person(name,age) 
  2. var o = new Object; 
  3. o.name=name; 
  4. o.age=age; 
  5. o.show=function() 
  6.     return ("my name is "+o.name+",and my age is "+o.age); 
  7. return o; 
  8. var per = new Person("yuan",20); 
  9. alert(per.show()); 
function Person(name,age)
{
var o = new Object;
o.name=name;
o.age=age;
o.show=function()
{
	return ("my name is "+o.name+",and my age is "+o.age);
}
return o;
}
var per = new Person("yuan",20);
alert(per.show());

3、

[javascript] view plain copy print ? 在CODE上查看代码片 派生到我的代码片
  1. var per= 
  2.     name:"yuan"
  3.     age:20, 
  4.     show:function() 
  5.     return ("my name is "+this.name+",and my age is "+this.age); 
  6. alert(per.show()); 
var per=
{
	name:"yuan",
	age:20,
	show:function()
{
	return ("my name is "+this.name+",and my age is "+this.age);
}
}
alert(per.show());

以上三种方式的输出结果相同。


二 、获取构造器方法

   所有构造器均是类,但并非所有类是构造器。内建类都是用构造器创建对象,而宿主对象(window等)则不是,对于实例对象而言,利用其constructor属性,可获取构造器方法:

[javascript] view plain copy print ? 在CODE上查看代码片 派生到我的代码片
  1. function Person(name,age) 
  2. this.name=name; 
  3. this.age=age; 
  4. this.show=function() 
  5.     return ("my name is "+this.name+",and my age is "+this.age); 
  6. var per = new Person("yuan",20); 
  7. alert(per.constructor); 
function Person(name,age)
{
this.name=name;
this.age=age;
this.show=function()
{
	return ("my name is "+this.name+",and my age is "+this.age);
}
}
var per = new Person("yuan",20);
alert(per.constructor);

运行结果:


内建类和宿主对象的constructor属性不能得到构造方法。


三 、使用prototype属性定义方法和属性

    除了在类的构造器定义方法和属性外,也可以用prototype定义。

[javascript] view plain copy print ? 在CODE上查看代码片 派生到我的代码片
  1. <span style="font-size:18px;">function Person(){} 
  2. Person.prototype.name="yuan";           //定义属性 
  3. Person.prototype.age=20;            
  4. Person.prototype.show=function()        //定义方法 
  5.     return ("my name is "+this.name+",and my age is "+this.age); 
  6. var per = new Person; 
  7. alert(per.show());</span> 
<span style="font-size:18px;">function Person(){}
Person.prototype.name="yuan";           //定义属性
Person.prototype.age=20;           
Person.prototype.show=function()        //定义方法
{
	return ("my name is "+this.name+",and my age is "+this.age);
}
var per = new Person;
alert(per.show());</span>


四 、类的成员的访问控制

    1、public成员:使用this和prototype定义的属性和方法是公共成员,可以在脚本的任何位置访问


    2、private成员:定义属性用var,定义方法时采用命名函数或者匿名函数

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值