关于JavaScript面向对象的学习

JavaScript对象是什么

 

JavaScript中所有的事物都是对象,对象就是包含一组变量和函数的集合,或者说对象只是带有属性和方法的特殊数据类型。在其它面向对象语言中对象是类的实例化来的,JavaScript其它面向对象的语言不同的是JavaScript是基于原型的面向对象语言,没有类的概念,所有的一切对象都派生自现有对象的一个副本。

 

创建JavaScript对象

 

JavaScript本身包含很多对象,包括Array、String、Boolean、Number、Mah、Data、RegExp、Global等。除此之外JavaScript还允许自定义对象。

通过JavaScript,我们可以定义并创建自己的对象。创建新对象有两种不同的方法:

1.定义并创建对象的实例使用Object;

2.使用构造函数Function来定义对象,然后创建新的对象实例。

 

方法1 Object

 

 

Object方法来创建一个对象以及它的实例:

 

[javascript]

  1. varperson=new Object();
  2. person.firstname="Bill";
  3. person.lastname="Gates";
  4. person.age=56;
  5. person.eyecolor="blue";


 

 

 

实例:

 

[javascript]

  1. person={firstname:"John",lastname:"Doe",age:50,eyecolor:"blue"};


 

 

 

方法2 Fucntion

 

使用Fucntion构造函数来创造对象以及它的实例

 

 

[javascript]

  1. function person(firstname,lastname,age,eyecolor)
  2. {
  3. this.firstname=firstname;
  4. this.lastname=lastname;
  5. this.age=age;
  6. this.eyecolor=eyecolor;
  7. }


 

 

 

使用构造函数创建对象实例


[javascript]

  1. var myFather=newperson("Bill","Gates",56,"blue");


 

 

 

备注:在使用构造函数创造对象时,还有另一种创造对象的方法,但是这种方法在性能上不如上面这种方法,在声明顺序上有严格的要求,使用起来不是很方便,所以不建议使用:

 

[javascript]

  1. var person=new Function (firstname,this.firstname=firstname;lastname,this.lastname=lastname;age,this.age=age;eyecolor,
  2. this.eyecolor=eyecolor;
  3. );


 

 

 

添加成员

 

添加静态成员

 

1 Object方法

 

Object对象添加静态成员只存在于对象的myObj实例而不存在构造函数中。

 

 

[javascript]

  1. var myObj= newObject();
  2. //添加name属性
  3. myObj.name='LD';
  4. //添加alertName方法
  5. myObj.alertName=function(){
  6. alert(this.name);
  7. }
  8. //执行alertName
  9. myObj.alertName();


 

 

 

2 Function方法

 

Function添加静态成员可以存在myObj实例,也可存在构造函数中。

 

 

[javascript]

  1. var myObj=newfunction(){
  2. //添加静态属性
  3. myObj.name='LD';
  4. //添加静态方法
  5. myObj.alertName=function(){
  6. alert(this.nam);
  7. }
  8. }
  9. myObj.alertName();


 

 

 

关于上面添加的静态成员,只能应用于myObj这个实例中,不能应用于其它的实例中,否则会报错,这就是静态成员的应用。

 

添加公有成员

 

能够使实例化的对象包含的方法称为公有成员,需要修改函数的原型,即prototype属性,修改后,任何继承该对象的对象已经存在的所有实例都会立即继承统一的变化。

 

 

 

[javascript]

  1. functionmyConstructor(){
  2. }
  3. //添加公有属性
  4. myConstructor.prototype.myName='LD';
  5. //实例化
  6. var myObj=newmyConstructor();
  7. alert(myObj.myName);


 

 

 

由myConstructor实例化的对象可以使用myName,但是myConstructor本身不可以,因为我们把公有成员加到了myConstructor的底层定义中,而非myConstructor实例本身。

 

添加私有成员

 

私有成员就是在构造函数中定义的变量和函数,这个比较简单只要在构造函数大括号中的属性和方法都算是私有的。

 

 

[javascript]

  1. functionmyConstructor(){
  2. //添加私有属性
  3. var myName='Ld'l
  4. //添加私有方法
  5. varalertName=function(){
  6. alert('LD');
  7. }
  8. alertName();


 

 

 

 

添加特权成员

 

特权成员与私有成员不同,特权成员能够被公开访问,而且还能访问私有成员,特权成员是指在构造函数的作用域中使用this定义的方法

 

 

[javascript]

  1. functionmyConstructor(){
  2. //私有属性
  3. varname='Devin';
  4. // 特权方法
  5. this.alertName=function(){
  6. alert(name);
  7. }
  8. }


 

 

 

成员之间比较

 

私有成员和特权成员都再函数的内部,他们会被带到函数的每一个实例中,因而将占用大量的内存;公有的原型成员是对象蓝图的一部分,适用于通过new关键字实例化该对象的每一个实例;静态成员只适用于对象的一个特殊实例。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值