主页 > 软件开发  > 

js几种对象创建方式

js几种对象创建方式

适用于不确定对象内部数据

方式一:

var p = new Object(); p.name = 'TOM'; p.age = 12 p.setName = function(name) { this.name = name; } // 测试 p.setName('jack') console.log(p.name,p.age)

方式二: 对象字面量模式

套路:使用{}创建对象,同时指定属性、方法

适用场景:起始时对象内部数据是确定的

问题:如果创建多个对象,有重复代码

var p = { name: 'TOM', age: 12, setName: function(name) { this.name = name; } } // 测试 console.log(p.name,p.age)// TOM 12 p.setName('JACK'); console.log(p.name,p.age)// JACK 12 如果创建多个对象,代码重复 var p2 = { name: 'TOM', age: 13, setName: function(name) { this.name = name; } }

方式三:工厂模式

套路:通过工厂函数动态创建对象并返回

适用场景: 需要创建多个对象

问题: 对象没有一个具体的类型都是Object类型

function createPerson (name,age) {// 返回一个对象的函数=》 工厂函数 var obj = { name: name, age: age,      setName: function(name) { this.name = name; }     } return obj } var p1 = createPerson('Tom',12) var p1 = createPerson('Jack',13)

方式四:自定义构造函数模式

套路: 自定义构造函数,通过new创建对象

适用场景: 需要创建多个类型确定得对象

问题: 每个对象都有相同得数据,消费内存

// 定义类型 function Person(name,age) { this.name = name; this.age = age; this.setName = function(name) { this.name = name;     } } var p1 = new Person('TOM',12) P1.setName('JACK') console.log(p1.name,p1.age)

方式六:构造函数+原型的组合模式

*套路: 自定义构造函数,属性在函数中初始化,方法添加到原型上

*适用场景:需要创建多个类型确定的对象

function Person(name,age) { // 在构造函数中只初始化一般函数 this.name = name; this.age = age; Person.prototype.setName = function(name) {     this.name = name;     } } var p1 = new Person('tom',12) var p1 = createPerson('jack',13) console.log(p1,p2)

原文链接:

37.尚硅谷_JS高级_对象创建模式_哔哩哔哩_bilibili

标签:

js几种对象创建方式由讯客互联软件开发栏目发布,感谢您对讯客互联的认可,以及对我们原创作品以及文章的青睐,非常欢迎各位朋友分享到个人网站或者朋友圈,但转载请说明文章出处“js几种对象创建方式