本文实例讲述了JS常见创建类的方法。分享给大家供大家参考,具体如下:

Javascript是一种基于对象的语言,你遇到的所有东西几乎都是对象。但是,它又不是一种真正的面向对象编程(OOP)语言,因为它的语法中没有Class。(不过,ES6引入了Class这个概念,作为对象的模板。通过class关键字,可以定义类。ES6入门:http://es6.ruanyifeng.com/)。
但是在项目开发中,经常用到JS面向对象开发,这就需要我们去用JS创建类,从而去实例化一些对象。接下来我们介绍一下在JS中创建类的几种方式:
1.工厂方式:
//通过工厂方式创建对象,先定义一个工厂方法
function createObj(){
var obj = new Object();
obj.name="xxx";
obj.say=function(){
alert("我是xxx");
}
return obj;
}
//调用工厂方法创建对象:
var obj1 = createObj();
//也可以用这种形式
function createObj(){
var obj = {}; //这样生成对象
obj.name="xxx";
obj.say=function(){
alert("我是xxx");
}
return obj;
}
var obj1 = createObj();
这种方式的问题是每一次通过工厂方法去创建一个对象,这个对象的属性name和方法say都必须重新创建一次,浪费内存。
2.构造器方式:
//创建一个构造器,构造函数首字母大写
function Obj(){
this.name="xxx";
this.say=function(){
alert("我是xxx");
};
}
//利用构造器,通过new关键字生成对象
var obj1=new Obj();
这是最基本的方式,但是也存在和工厂方式一样的毛病。
3.原型方式:
//用空函数创建一个类
function Obj(){
}
//在类的原型链上添加属性和方法
Obj.prototype.name="xxx";
Obj.prototype.say=function(){
alert("我是xxx");
}
//生成对象
var obj1=new Obj();
这个方式的缺点是,当有引用属性时,改变一个对象的这个属性也会改变其他对象的这个属性。因为一个引用属性,都是指向的同一个地方。
4.原型/构造联合方式
//用构造函数定义对象的非函数属性
function Obj(name){
this.name=name;
this.arr=new Array('a','b');
}
//用原型方式定义对象的方法
Obj.prototype.say=function(){
alert("我是xxx");
}
//生成对象
var obj1 = new Obj('xxx');
这种是目前用的最多的创建类和对象的方式,将方法和属性用不同的方式封装。
5.动态原型方式
//动态原型方式和原型/构造混合方式的原理相似,唯一的区别就是赋予对象方法的位置
function Person(name, sex) {
this.name = name;
this.sex = sex;
if (typeof this.say != "function") {
Person.prototype.say = function () {
alert(this.name);
}
}
}
var man =new Person ("凯撒", "男");
man.say();//凯撒
动态原型模式是将所有的信息都封装到构造函数中,构造函数中,只用say不存在的情况下,才会将它添加到原型中。这段代码只有在初次调用时才会执行。
实例化obj对象有三步:
1. 创建obj对象:
obj=new Object();
2. 将obj的内部__proto__指向构造他的函数Obj的prototype,同时,obj.constructor===Obj.prototype.constructor,从而使得obj.constructor.prototype指向Obj.prototype(obj.constructor.prototype===A.prototype)。obj.constructor.prototype与的内部_proto_是两码事,实例化对象时用的是_proto_,obj是没有prototype属性的,但是有内部的__proto__,通过__proto__来取得原型链上的原型属性和原型方法。
3. 将obj作为this去调用构造函数Obj,从而设置成员(即对象属性和对象方法)并初始化。
当这3步完成,这个obj对象就与构造函数Obj再无联系,这个时候即使构造函数Obj再加任何成员,都不再影响已经实例化的obj对象了。
更多关于JavaScript相关内容感兴趣的读者可查看本站专题:《javascript面向对象入门教程》、《JavaScript错误与调试技巧总结》、《JavaScript数据结构与算法技巧总结》、《JavaScript遍历算法与技巧总结》及《JavaScript数学运算用法总结》
希望本文所述对大家JavaScript程序设计有所帮助。
# JS
# 创建类
# 工厂方式
# 构造器方式
# 原型方式
# 联合方式
# Javascript使用function创建类的两种方法(推荐)
# Javascript 创建类并动态添加属性及方法的简单实现
# JS创建类和对象的两种不同方式
# JavaScript中创建类/对象的几种方法总结
# JavaScript创建类/对象的几种方式概述及实例
# javascript最常用与实用的创建类的代码
# 利用MS AJAX注册Javascript命名空间并创建类
# 讨论javascript(一)工厂方式 js面象对象的定义方法
# javascript工厂方式定义对象
# JavaScript中使用构造器创建对象无需new的情况说明
# JavaScript设计模式之工厂模式和构造器模式
# javascript 混合的构造函数和原型方式
# 动态原型方式
# 我是
# 凯撒
# 都是
# 创建一个
# 面向对象
# 的是
# 这是
# 是一种
# 也会
# 相关内容
# 最多
# 才会
# 可以用
# 遍历
# 感兴趣
# 这段
# 这就
# 数据结构
# 而去
# 给大家
相关文章:
怎么用手机制作网站链接,dw怎么把手机适应页面变成网页?
如何处理“XML格式不正确”错误 常见XML well-formed问题解决方法
建站之星多图banner生成与模板自定义指南
如何自定义建站之星网站的导航菜单样式?
如何在云主机快速搭建网站站点?
如何在万网自助建站平台快速创建网站?
如何在搬瓦工VPS快速搭建网站?
如何制作网站标识牌,动态网站如何制作(教程)?
微信小程序 五星评分(包括半颗星评分)实例代码
定制建站方案优化指南:企业官网开发与建站费用解析
大连网站制作费用,大连新青年网站,五年四班里的视频怎样下载啊?
javascript中的try catch异常捕获机制用法分析
网站制作报价单模板图片,小松挖机官方网站报价?
清除minerd进程的简单方法
宁波免费建站如何选择可靠模板与平台?
高防服务器租用如何选择配置与防御等级?
如何选择香港主机高效搭建外贸独立站?
如何通过智能用户系统一键生成高效建站方案?
如何在建站之星绑定自定义域名?
网站广告牌制作方法,街上的广告牌,横幅,用PS还是其他软件做的?
免费制作海报的网站,哪位做平面的朋友告诉我用什么软件做海报比较好?ps还是cd还是ai这几个软件我都会些我是做网页的?
焦点电影公司作品,电影焦点结局是什么?
PHP正则匹配日期和时间(时间戳转换)的实例代码
建站之星云端配置指南:模板选择与SEO优化一键生成
如何在云服务器上快速搭建个人网站?
营销式网站制作方案,销售哪个网站招聘效果最好?
如何通过.red域名打造高辨识度品牌网站?
网站规划与制作是什么,电子商务网站系统规划的内容及步骤是什么?
建站之星手机一键生成:多端自适应+小程序开发快速建站指南
制作电商网页,电商供应链怎么做?
建站10G流量真的够用吗?如何应对访问高峰?
建站主机服务器选购指南:轻量应用与VPS配置解析
山东网站制作公司有哪些,山东大源集团官网?
行程制作网站有哪些,第三方机票电子行程单怎么开?
做企业网站制作流程,企业网站制作基本流程有哪些?
电商网站制作价格怎么算,网上拍卖流程以及规则?
常州自助建站费用包含哪些项目?
广州美橙建站如何快速搭建多端合一网站?
建站之星导航配置指南:自助建站与SEO优化全解析
python的本地网站制作,如何创建本地站点?
网站制作模板下载什么软件,ppt模板免费下载网站?
如何在Golang中实现微服务服务拆分_Golang微服务拆分与接口管理方法
建站之星×万网:智能建站系统+自助建站平台一键生成
南阳网站制作公司推荐,小学电子版试卷去哪里找资源好?
大连 网站制作,大连天途有线官网?
如何高效配置IIS服务器搭建网站?
成都响应式网站开发,dw怎么把手机适应页面变成网页?
如何快速上传建站程序避免常见错误?
网站制作难吗安全吗,做一个网站需要多久时间?
沈阳制作网站公司排名,沈阳装饰协会官方网站?
*请认真填写需求信息,我们会在24小时内与您取得联系。