javascript中类的定义方式详解(四种方式)


Posted in Javascript onDecember 22, 2015

本文实例讲述了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模板技术
Apr 27 Javascript
DOM 基本方法
Jul 18 Javascript
JavaScript小技巧 2.5 则
Sep 12 Javascript
关于javascript中的typeof和instanceof介绍
Dec 04 Javascript
基于jquery的文字向上跑动类似跑马灯的效果
Sep 22 Javascript
jquery ui bootstrap 实现自定义风格
Nov 14 Javascript
JQuery操作元素的css样式
Mar 09 Javascript
vue-router路由参数刷新消失的问题解决方法
Jun 17 Javascript
jQuery上传插件webupload使用方法
Aug 01 jQuery
react-native使用react-navigation进行页面跳转导航的示例
Sep 07 Javascript
vue打包之后生成一个配置文件修改接口的方法
Dec 09 Javascript
layui扩展上传组件模拟进度条的方法
Sep 23 Javascript
jquery获取select选中值的方法分析
Dec 22 #Javascript
JS设置下拉列表框当前所选值的方法
Dec 22 #Javascript
点评js异步加载的4种方式
Dec 22 #Javascript
JS模拟按钮点击功能的方法
Dec 22 #Javascript
jquery插件jquery.confirm弹出确认消息
Dec 22 #Javascript
js实现仿微博滚动显示信息的效果
Dec 21 #Javascript
Javascript实现Array和String互转换的方法
Dec 21 #Javascript
You might like
php获取错误信息的方法
2015/07/17 PHP
学习php设计模式 php实现单例模式(singleton)
2015/12/07 PHP
Laravel使用swoole实现websocket主动消息推送的方法介绍
2019/10/20 PHP
PHP 面向对象程序设计之类属性与类常量实现方法分析
2020/04/13 PHP
php实现统计IP数及在线人数的示例代码
2020/07/22 PHP
javascript 基础篇2 数据类型,语句,函数
2012/03/14 Javascript
javascript文本框内输入文字倒计数的方法
2015/02/24 Javascript
JavaScript中逗号运算符介绍及使用示例
2015/03/13 Javascript
jQuery实现自动切换播放的经典滑动门效果
2015/09/12 Javascript
jQuery简单实现MD5加密的方法
2017/03/03 Javascript
js操作table中tr的顺序实现上移下移一行的效果
2018/11/22 Javascript
JavaScript变量提升和严格模式实例分析
2019/01/27 Javascript
vue 点击展开显示更多(点击收起部分隐藏)
2019/04/09 Javascript
如何使用Node.js爬取任意网页资源并输出PDF文件到本地
2019/06/17 Javascript
[33:23]VG vs Pain 2018国际邀请赛小组赛BO2 第二场 8.18
2018/08/19 DOTA
[01:04:14]VP vs TNC 2018国际邀请赛小组赛BO2 第二场 8.17
2018/08/20 DOTA
探索Python3.4中新引入的asyncio模块
2015/04/08 Python
Python实现PS滤镜的旋转模糊功能示例
2018/01/20 Python
Python切片索引用法示例
2018/05/15 Python
用Python将mysql数据导出成json的方法
2018/08/21 Python
Python tkinter的grid布局及Text动态显示方法
2018/10/11 Python
一个可以套路别人的python小程序实例代码
2019/04/09 Python
Python collections中的双向队列deque简单介绍详解
2019/11/04 Python
CSS3+font字体文件实现圆形半透明菜单具体步骤(图解)
2013/06/03 HTML / CSS
Spartoo芬兰:欧洲最大的网上鞋店
2016/08/28 全球购物
百联网上商城:i百联
2017/01/28 全球购物
Charles&Keith美国官方网站:新加坡快时尚鞋类和配饰零售商
2019/11/27 全球购物
教师实习自我鉴定
2013/12/18 职场文书
大学生家政服务项目创业计划书
2014/01/30 职场文书
《吃水不忘挖井人》教学反思
2014/04/15 职场文书
教导主任竞聘演讲稿
2014/05/16 职场文书
股东出资证明书(正规版)
2014/09/24 职场文书
一年级数学上册复习计划
2015/01/17 职场文书
2015年出纳年终工作总结
2015/05/14 职场文书
入党转正申请自我鉴定
2019/06/25 职场文书
Python基础之函数嵌套知识总结
2021/05/23 Python