
您可以在 repo github 上找到这篇文章中的所有代码。
对象创建方法
基于构造函数
es6之前推荐。
WebmengWeb企业管理系统也简称“WebmengWeb”,是由创梦公司历时3年开发一款以电脑版+微信站+APP+手机版+PAD网站的多语言网站全方组合的营销型企业网站管理系统。WebmengWeb以PHP5+MYSQL做为技术基础进行开发,采用OOP(面向对象)方式进行基础运行框架搭建。模块化开发方式做为功能开发形式,框架易于功能扩展,代码维护,优秀的二次开发能力,可满足所有网站的应用需求。
/**
* @param {string} firstname
* @param {string} lastname
* @param {number} age
*/
function person(firstname, lastname, age) {
this.firstname = firstname;
this.lastname = lastname;
this.age = age;
this.greet = function () {
console.log(`hello, my name is ${this.firstname} ${this.lastname}`);
};
}
// usage example
const person1 = new person("john", "doe", 30);
person1.greet(); // => hello, my name is john doe
const person2 = new person("jane", "smith", 25);
person2.greet(); // => hello, my name is jane smith
基于类别
es6 之后推荐。
class person {
constructor(firstname, lastname, age) {
this.firstname = firstname;
this.lastname = lastname;
this.age = age;
}
greet() {
console.log(`hello, my name is ${this.firstname} ${this.lastname}`);
}
}
// usage example
const person1 = new person("john", "doe", 30);
person1.greet(); // => 'hello, my name is john doe'
const person2 = new person("jane", "smith", 25);
person2.greet(); // => 'hello, my name is jane smith'
对象初始值设定项
const person = {
firstname: "john",
lastname: "doe",
age: 30,
greet: function () {
console.log(`hello, my name is ${this.firstname} ${this.lastname}`);
},
};
person.greet(); // => 'hello, my name is john doe'
对象.create()
const personprototype = {
greet: function () {
console.log(`hello, my name is ${this.firstname} ${this.lastname}`);
},
};
const person = object.create(personprototype);
person.firstname = "john";
person.lastname = "doe";
// usage example
person.greet(); // => 'hello, my name is john doe'
工厂模式
/**
* @param {string} firstName
* @param {string} lastName
* @param {number} age
* @return {object}
*/
function createPerson(firstName, lastName, age) {
return {
firstName: firstName,
lastName: lastName,
age: age,
greet: function () {
console.log(`Hello, my name is ${this.firstName} ${this.lastName}`);
},
};
}
// Usage example
const person1 = createPerson("John", "Doe", 30);
person1.greet(); // => 'Hello, my name is John Doe'
const person2 = createPerson("Jane", "Smith", 25);
person2.greet(); // => 'Hello, my name is Jane Smith'
参考
- 类 - mdn
- 面向对象编程 - mdn
- 面向对象编程 - mdn
- 对象初始值设定项 - mdn
- object.create() - mdn
- 工厂模式-patterns.dev









