JS创建多个对象有什么方法,具体是怎样的
Admin 2022-07-14 群英技术资讯 690 次浏览
关于“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进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
这篇文章主要为大家介绍了Vue的监听属性,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助
怎样用js实现循环轮播图?对于轮播图的应用场景有很多,但是一些新手可能对于循环轮播图的实现不是很了解,对此这篇文章就给大家分享怎样用js写一个循环轮播图的代码,感兴趣的朋友可以参考。
本篇文章带大家学习一下React,深入了解下React中的任务调度算法,希望对大家有所帮助!
JavaScript如何生成唯一id?有哪些方法?很多刚接触JavaScript的朋友,可能对于生成唯一ID的方式不是很了解,因此,下面小编就给大家分享一些JavaScript生成唯一id方法,需要的朋友可以参考。
这篇文章主要介绍了Vue 防止短时间内连续点击后多次触发请求的操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008