首页 > web前端 > js教程 > 正文

对象创建 - JavaScript 挑战

花韻仙語
发布: 2024-11-03 13:57:02
转载
404人浏览过

对象创建 - javascript 挑战

您可以在 repo github 上找到这篇文章中的所有代码。


对象创建方法


基于构造函数

es6之前推荐。

PHPCMS V9
PHPCMS V9

PHPCMS V9(后面简称V9)采用PHP5+MYSQL做为技术基础进行开发。V9采用OOP(面向对象编程)+ MVC设计模式,进行基础运行框架搭建。模块化开发方式做为功能开发形式。框架易于功能扩展,代码维护,优秀的二次开发能力,可满足所有网站的应用需求。 5年开发经验的优秀团队,在掌握了丰富的WEB开发经验和CMS产品开发经验的同时,勇于创新追求完美的设计理念,为全球多达10万网站提供助力,并

PHPCMS V9 296
查看详情 PHPCMS V9
/**
 * @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

以上就是对象创建 - JavaScript 挑战的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:dev.to网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号