JS创建多个对象有什么方法,具体是怎样的
Admin 2022-07-14 群英技术资讯 818 次浏览
关于“JS创建多个对象有什么方法,具体是怎样的”的知识有一些人不是很理解,对此小编给大家总结了相关内容,具有一定的参考借鉴价值,而且易于学习与理解,希望能对大家有所帮助,有这个方面学习需要的朋友就继续往下看吧。
在开发过程中我们经常会遇到需要创建很多个相似的对象,很可能有很多相同的属性或方法,那我们创建多个对象的方法都有哪些呢?最好的方法有又是哪个呢?一起来来看看吧!
对象的字面量方方式是创建对象最常用的方式之一,以字面量方式创建的对象属性默认是可写的、可枚举、可配置。
如下代码展示了使用字面量方式创建多个对象:
// 字面量方式创建多个对象
var person1 = {
name: 'jam',
age: 18,
address: '上海市',
eating: function () {
console.log(this.name + '在吃饭')
}
}
var person2 = {
name: 'tom',
age: 20,
address: '北京市',
eating: function () {
console.log(this.name + '在吃饭')
}
}
var person3 = {
name: 'liming',
age: 19,
address: '天津市',
eating: function () {
console.log(this.name + '在吃饭')
}
}
经过上述示例代码我们可以看出,仅仅创建了3个对象就用了24行,可以看出字面量方式的弊端:创建同样的对象时,需要编写重复的代码太多。
工厂模式其实是一种常见的设计模式;
通常我们会有一个工厂方法,通过该工厂方法我们可以产生想要的对象;
如下代码展示了使用工厂模式方法创建多个对象的操作:
// 工厂函数方式创建多个对象
function createPerson (name, age, address) {
var p = {}
p.name = name
p.age = age
p.address = address
p.eating = function () {
console.log(name + '在吃饭')
}
return p
}
var p1 = createPerson('jam', 19, '上海市')
var p2 = createPerson('tom', 14, '北京市')
var p3 = createPerson('li', 13, '天津市')
p3.eating() // li在吃饭
可以看出使用工厂模式方法创建了三个对象使用的代码明显比字面量少了好多行,but这就是最好的方式了吗?NO! NO! NO!工厂模式方法的**弊端**就在于:以上述示例代码为例。当我们打印p1,p2,p3后,获取不到对象最真实的类型,比如p1是人还是动物还是工具
构造函数相信大家并不陌生。所谓构造函数,就是提供一个生成对象的模板,并描述对象的基本结构的函数。一个构造函数,可以生成多个对象,每个对象都有相同的结构。
如下代码展示了使用构造函数方法创建多个对象:
// 约定俗成的规范,构造函数名字首字母大写
function Person (name, age, address) {
this.name = name
this.age = age
this.address = address
this.eating = function () {
console.log(this.name + '在吃饭')
}
this.running = function () {
console.log(this.name + '在跑步')
}
}
var p1 = new Person('jam', 20, '北京市')
var p2 = new Person('tom', 14, '上海市')
var p3 = new Person('li', 13, '天津市')
console.log(p1)
// 输出结果
// Person {
// name: 'jam',
// age: 20,
// address: '北京市',
// eating: [Function],
// running: [Function]
// }
p1.eating() // jam在吃饭
构造函数有个不成文的规范,那就是构造函数的名字首字母大写或者驼峰。构造函数方式并不是最完美的创建多个对象的方式,也是有缺点的。缺点:每个方法都要在每个实例上重新创建一遍,比如同样的eating方法和running方法都需要在p1,p2,p3的实例上去创建一遍,浪费很多的内存空间
二者的组合模式即在构造函数上定义实例属性,那么在创建对象上只需要传入这些参数。在原型对象用于定义方法和共享属性。
如下代码展示了使用原型加构造函数方式创建多个对象:
function Person (name, age, address) {
this.name = name
this.age = age
this.address = address
this.eating =
this.running = function () {
console.log(this.name + '在跑步')
}
}
// 将eating方法和running方法加在原型上,就不需要每次创建一个对象都去在内存中加一遍一样的方法
Person.prototype.eating = function () {
console.log(this.name + '在吃饭')
}
Person.prototype.running = function () {
console.log(this.name + '在跑步')
}
var p1 = new Person('jam', 20, '北京市')
var p2 = new Person('tom', 14, '上海市')
var p3 = new Person('li', 13, '天津市')
console.log(p1)
// 输出结果:
// Person {
// name: 'jam',
// age: 20,
// address: '北京市',
// eating: [Function],
// running: [Function]
// }
p1.eating() // jam在吃饭
最后的当然是压轴的呀,这种原型和构造函数方式是目前在ECMAScript中使用得最广泛、认同度最高的一种创建对象的方法。
看完之后是不是感觉创建多个对象也没有那么复杂,利用原型加构造函数的方法分分钟创建好了。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
Vue3 在经过多个开发版本的迭代后,终于迎来了它的正式版本,下面这篇文章主要给大家介绍了关于如何使用vue3实现一个人喵交流小程序的相关资料,需要的朋友可以参考下
这篇文章主要给大家分享的是Vue3的几个优势,Vue3仍然在源码、性能和语法 API 三个大的方面进行了优化,下面我们一起进入文章看看具体详情吧
本篇文章带大家学习一下React,深入了解下React中的任务调度算法,希望对大家有所帮助!
这篇文章主要介绍了VUE使用ElementUI下拉框 @change事件数据不回显问题。具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
今天给大家分享的是JavaScript中状态容器Redux的使用,下文对Redux的使用有很详细的介绍及实例可以参考,感兴趣的朋友可以了解看看,接下来跟随小编来学习一下吧。
成为群英会员,开启智能安全云计算之旅
立即注册关注或联系群英网络
7x24小时售前:400-678-4567
7x24小时售后:0668-2555666
24小时QQ客服
群英微信公众号
CNNIC域名投诉举报处理平台
服务电话:010-58813000
服务邮箱:service@cnnic.cn
投诉与建议:0668-2555555
Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 ICP核准(ICP备案)粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008