javascript中类的定义方式详解(四种方式)
2015-12-22 00:00
661 查看
本文实例讲述了javascript中类的定义方式。分享给大家供大家参考,具体如下:
类的定义包括四种方式:
1、工厂方式
定义了一个能创建并返回特定类型对象的工厂函数, 看起来还是不错的, 但有个小问题 ,
每次调用时都要创建新函数 showColor,我们可以把它移到函数外面,
在工厂函数中直接指向它
这样避免了重复创建函数的问题,但看起来不像对象的方法了。
2、构造函数方式
可以看到与第一中方式的差别,在构造函数内部无创建对象,而是使用 this 关键字。
使用 new 调用构造函数时,先创建了一个对象,然后用 this 来访问。
这种用法于其他面向对象语言很相似了, 但这种方式和上一种有同一个问题, 就是重复创建函数。
3、原型方式
首先定义了构造函数 Car,但无任何代码,然后通过 prototype 添加属性。优点:
a. 所有实例存放的都是指向 showColor 的指针,解决了重复创建函数的问题
b. 可以用 instanceof 检查对象类型
缺点,添加下面的代码:
drivers 是指向 Array 对象的指针,proCar 的两个实例都指向同一个数组。
4、动态原型方式
这种方式是我最喜欢的, 所有的类定义都在一个函数中完成, 看起来非常像其他语言的类定义,不会重复创建函数,还可以用 instanceof
希望本文所述对大家JavaScript程序设计有所帮助。
javascript中定义类的方法详解
javascript中定义类的方法汇总
JavaScript定义类的几种方式总结
javascript中类的定义及其方式(《javascript高级程序设计》学习笔记)
javascript来定义类的规范小结
JavaScript 类的定义和引用 JavaScript高级培训 自定义对象
获取JavaScript用户自定义类的类名称的代码
类的定义包括四种方式:
1、工厂方式
function createCar(name,color,price){ var tempcar=new Object; tempcar.name=name; tempcar.color=color; tempcar.price=price; tempcar.getName=function(){ document.write(this.name+"-----"+this.color+"<br>"); }; return tempcar; } var car1=new createCar("工厂桑塔纳","red","121313"); car1.getName();
定义了一个能创建并返回特定类型对象的工厂函数, 看起来还是不错的, 但有个小问题 ,
每次调用时都要创建新函数 showColor,我们可以把它移到函数外面,
function getName(){ document.write(this.name+"-----"+this.color+"<br>"); }
在工厂函数中直接指向它
tempCar.getName = getName;
这样避免了重复创建函数的问题,但看起来不像对象的方法了。
2、构造函数方式
function Car(name,color,price){ this.name=name; this.color=color; this.price=price; this.getColor=function(){ document.write(this.name+"-----"+this.color+"<br>"); }; } var car2=new Car("构造桑塔纳","red","121313"); car2.getColor();
可以看到与第一中方式的差别,在构造函数内部无创建对象,而是使用 this 关键字。
使用 new 调用构造函数时,先创建了一个对象,然后用 this 来访问。
这种用法于其他面向对象语言很相似了, 但这种方式和上一种有同一个问题, 就是重复创建函数。
3、原型方式
function proCar(){ } proCar.prototype.name="原型"; proCar.prototype.color="blue"; proCar.prototype.price="10000"; proCar.prototype.getName=function(){ document.write(this.name+"-----"+this.color+"<br>"); }; var car3=new proCar(); car3.getName();
首先定义了构造函数 Car,但无任何代码,然后通过 prototype 添加属性。优点:
a. 所有实例存放的都是指向 showColor 的指针,解决了重复创建函数的问题
b. 可以用 instanceof 检查对象类型
alert(car3 instanceof proCar);//true
缺点,添加下面的代码:
proCar.prototype.drivers = newArray("mike", "sue"); car3.drivers.push("matt"); alert(car3.drivers);//outputs "mike,sue,matt" alert(car3.drivers);//outputs "mike,sue,matt"
drivers 是指向 Array 对象的指针,proCar 的两个实例都指向同一个数组。
4、动态原型方式
function autoProCar(name,color,price){ this.name=name; this.color=color; this.price=price; this.drives=new Array("mike","sue"); if(typeof autoProCar.initialized== "undefined"){ autoProCar.prototype.getName =function(){ document.write(this.name+"-----"+this.color+"<br>"); }; autoProCar.initialized=true; } } var car4=new autoProCar("动态原型","yellow","1234565"); car4.getName(); car4.drives.push("newOne"); document.write(car4.drives);
这种方式是我最喜欢的, 所有的类定义都在一个函数中完成, 看起来非常像其他语言的类定义,不会重复创建函数,还可以用 instanceof
希望本文所述对大家JavaScript程序设计有所帮助。
您可能感兴趣的文章:
javascript定义类和类的实现实例详解javascript中定义类的方法详解
javascript中定义类的方法汇总
JavaScript定义类的几种方式总结
javascript中类的定义及其方式(《javascript高级程序设计》学习笔记)
javascript来定义类的规范小结
JavaScript 类的定义和引用 JavaScript高级培训 自定义对象
获取JavaScript用户自定义类的类名称的代码
相关文章推荐
- JavaScript判断对象是否为数组
- JS控制按钮10秒钟后可用的方法
- JS实现的表格操作类详解(添加,删除,排序,上移,下移)
- JavaScript+CSS无限极分类效果完整实现方法
- IE6-IE9使用JSON、table.innerHTML所引发的问题
- 对象题目的一个坑 理解Javascript对象
- js仿微博实现统计字符和本地存储功能
- JavaScript 查找数组中最大值与最小值
- JSP&Servlet路径问题
- JavaScript语言精粹读书笔记
- JS实现按钮清除单击事件,或单击事件执行一次
- 求某范围质数 J2EE版及JS版
- js 基本介绍
- jsp开发中的4个域对象
- session问题和JSP
- js 类型转换
- HTML5入门2---js获取HTML元素的值
- JavaScript window对象 - 浏览器对象模型(BOM),使 JavaScript 有能力与浏览器“对话”
- 模块——js功能(倒计时,幻灯)
- 了解 JS 原型