JavaScript学习篇之——面向对象
2013-12-04 08:44
85 查看
JavaScript对象是什么
JavaScript中所有的事物都是对象,对象就是包含一组变量和函数的集合,或者说对象只是带有属性和方法的特殊数据类型。在其它面向对象语言中对象是类的实例化来的,JavaScript其它面向对象的语言不同的是JavaScript是基于原型的面向对象语言,没有类的概念,所有的一切对象都派生自现有对象的一个副本。创建JavaScript对象
JavaScript本身包含很多对象,包括Array、String、Boolean、Number、Mah、Data、RegExp、Global等。除此之外JavaScript还允许自定义对象。通过JavaScript,我们可以定义并创建自己的对象。创建新对象有两种不同的方法:
1.定义并创建对象的实例使用Object;
2.使用构造函数Function来定义对象,然后创建新的对象实例。
方法1 Object
Object方法来创建一个对象以及它的实例:varperson=new Object(); person.firstname="Bill"; person.lastname="Gates"; person.age=56; person.eyecolor="blue";
实例:
person={firstname:"John",lastname:"Doe",age:50,eyecolor:"blue"};
方法2 Fucntion
使用Fucntion构造函数来创造对象以及它的实例function person(firstname,lastname,age,eyecolor) { this.firstname=firstname; this.lastname=lastname; this.age=age; this.eyecolor=eyecolor; }
使用构造函数创建对象实例
var myFather=newperson("Bill","Gates",56,"blue");
备注:在使用构造函数创造对象时,还有另一种创造对象的方法,但是这种方法在性能上不如上面这种方法,在声明顺序上有严格的要求,使用起来不是很方便,所以不建议使用:
var person=new Function (firstname,this.firstname=firstname;lastname,this.lastname=lastname;age,this.age=age;eyecolor, this.eyecolor=eyecolor; );
添加成员
添加静态成员
1 Object方法
Object对象添加静态成员只存在于对象的myObj实例而不存在构造函数中。var myObj= newObject(); //添加name属性 myObj.name='LD'; //添加alertName方法 myObj.alertName=function(){ alert(this.name); } //执行alertName myObj.alertName();
2 Function方法
Function添加静态成员可以存在myObj实例,也可存在构造函数中。var myObj=newfunction(){ //添加静态属性 myObj.name='LD'; //添加静态方法 myObj.alertName=function(){ alert(this.nam); } } myObj.alertName();
关于上面添加的静态成员,只能应用于myObj这个实例中,不能应用于其它的实例中,否则会报错,这就是静态成员的应用。
添加公有成员
能够使实例化的对象包含的方法称为公有成员,需要修改函数的原型,即prototype属性,修改后,任何继承该对象的对象已经存在的所有实例都会立即继承统一的变化。functionmyConstructor(){ } //添加公有属性 myConstructor.prototype.myName='LD'; //实例化 var myObj=newmyConstructor(); alert(myObj.myName);
由myConstructor实例化的对象可以使用myName,但是myConstructor本身不可以,因为我们把公有成员加到了myConstructor的底层定义中,而非myConstructor实例本身。
添加私有成员
私有成员就是在构造函数中定义的变量和函数,这个比较简单只要在构造函数大括号中的属性和方法都算是私有的。functionmyConstructor(){ //添加私有属性 var myName='Ld'l //添加私有方法 varalertName=function(){ alert('LD'); } alertName();
添加特权成员
特权成员与私有成员不同,特权成员能够被公开访问,而且还能访问私有成员,特权成员是指在构造函数的作用域中使用this定义的方法functionmyConstructor(){ //私有属性 varname='Devin'; // 特权方法 this.alertName=function(){ alert(name); } }
成员之间比较
私有成员和特权成员都再函数的内部,他们会被带到函数的每一个实例中,因而将占用大量的内存;公有的原型成员是对象蓝图的一部分,适用于通过new关键字实例化该对象的每一个实例;静态成员只适用于对象的一个特殊实例。相关文章推荐
- 学习javascript面向对象 实例讲解面向对象选项卡
- 【javascript基础篇】——面向对象动态加载属性和方法
- JavaScript面向对象程序设计(3): 对象
- 在Microsoft AJAX Library下JavaScript的面向对象开发
- [推荐]javascript 面向对象技术基础教程
- JS---感悟 JavaScript中的面向对象
- 原生javascript难点总结(1)---面向对象分析以及带来的思考
- JavaScript的面向对象
- javascript 中面向对象实现 如何继承
- JavaScript学习总结(5)——Javascript面向(基于)对象编程
- javascript 面向对象,实现namespace,class,继承,重载
- JavaScript之面向对象学习五(JS原生引用类型Array、Object、String等等)的原型对象介绍
- JavaScript之面向对象学习七(动态原型模式、寄生构造函数模式、稳妥构造函数模式创建自定义类型)
- 老生常谈javascript的面向对象思想
- 夺命雷公狗---javascript NO:20 面向对象历史起源
- 解析JavaScript面向对象概念中的Object类型与作用域
- JavaScript面向对象笔记–原型
- Javascript面向对象扩展库代码分享