JavaScript对象创建方式_JavaScript设计模式应用

字面量适合单个对象;2. 构造函数配合原型可批量创建并优化内存;3. ES6 class语法更清晰,推荐现代项目使用;4. 工厂函数灵活封装创建逻辑;5. 单例、建造者、工厂等设计模式依托不同创建方式实现,提升代码扩展性与维护性。

javascript对象创建方式_javascript设计模式应用

JavaScript 中创建对象的方式多种多样,不同的场景适合不同的模式。掌握这些方式不仅有助于写出更清晰的代码,还能为应用设计模式打下基础。下面介绍几种常见的对象创建方法,并结合设计模式说明其实际应用。

1. 字面量方式创建对象

这是最简单直接的方式,适用于创建单个对象。

const person = {  name: 'Alice',  age: 25,  greet() {    console.log(`Hello, I'm ${this.name}`);  }};person.greet();

适用场景:配置对象、临时数据结构、不需要复用逻辑时。这种方式不适合需要创建多个类似对象的情况。

2. 构造函数方式

使用函数作为构造器,通过 new 关键字生成实例,实现对象的批量创建。

立即学习“Java免费学习笔记(深入)”;

function Person(name, age) {  this.name = name;  this.age = age;  this.greet = function() {    console.log(`Hi, I'm ${this.name}`);  };}const p1 = new Person('Bob', 30);const p2 = new Person('Charlie', 35);

注意:每个实例都会重新创建 greet 函数,造成内存浪费。可通过原型链优化。

3. 原型方式(prototype)

将共享方法挂载在构造函数的 prototype 上,节省内存。

Person.prototype.greet = function() {  console.log(`Hello from ${this.name}`);};

现在所有 Person 实例共享同一个 greet 方法,提升性能。构造函数 + 原型组合模式是早期 JS 中创建对象的经典方式。

4. ES6 Class 语法

ES6 引入 class,让面向对象写法更清晰,本质仍是基于原型。

class Person {  constructor(name, age) {    this.name = name;    this.age = age;  }  greet() {    console.log(`I'm ${this.name}`);  }}

语法更接近传统语言,易于理解和维护,推荐在现代项目中使用。

5. 工厂函数模式

不依赖 new,返回一个新对象,适合需要封装创建逻辑的场景。

function createPerson(name, age) {  return {    name,    age,    greet() {      console.log(`Hey, I'm ${this.name}`);    }  };}const p = createPerson('Dana', 28);

工厂函数避免了 this 的指向问题,灵活且易于测试,适合复杂对象构建。

6. 设计模式中的应用

对象创建方式直接影响设计模式的实现效果。

单例模式:确保一个类只有一个实例。可通过闭包或模块模式实现。

  const Singleton = (function() {    let instance;    function create() {      return { name: 'Singleton' };    }    return {      getInstance() {        if (!instance) {          instance = create();        }        return instance;      }    };  })();  const s1 = Singleton.getInstance();  const s2 = Singleton.getInstance(); // 同一实例  

建造者模式:分步创建复杂对象,常用于配置项较多的场景。

  class ComputerBuilder {    constructor() {      this.computer = {};    }    setCPU(cpu) {      this.computer.cpu = cpu;      return this; // 支持链式调用    }    setRAM(ram) {      this.computer.ram = ram;      return this;    }    build() {      return this.computer;    }  }  const pc = new ComputerBuilder()    .setCPU('i7')    .setRAM('16GB')    .build();  

工厂模式:根据不同条件返回不同类型的对象。

  function createVehicle(type) {    if (type === 'car') {      return { wheels: 4, drive: () => console.log('Driving car') };    } else if (type === 'bike') {      return { wheels: 2, ride: () => console.log('Riding bike') };    }  }  

基本上就这些。选择合适的对象创建方式,能让代码更具扩展性和可维护性。结合设计模式,可以更好地组织逻辑,应对复杂需求。

以上就是JavaScript对象创建方式_JavaScript设计模式应用的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1539407.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月21日 11:34:25
下一篇 2025年12月21日 11:34:41

相关推荐

  • 理解JavaScript Promise的微任务队列与执行顺序

    本文深入探讨javascript中promise异步函数的执行顺序,特别是微任务队列的工作机制。通过一个具体的代码示例,我们将逐步解析promise的创建、状态变化以及`then`回调如何被调度和执行,揭示其背后的事件循环原理,帮助开发者清晰理解复杂的异步流程。 JavaScript异步编程与事件循…

    2025年12月21日
    000
  • JavaScript map 方法中处理循环元素为空数组的策略

    本文旨在深入探讨在javascript的`map`方法迭代过程中,如何高效地检测并处理作为当前循环元素的空数组。我们将通过具体场景和代码示例,展示如何利用`length`属性进行条件判断,从而实现针对空数组的特定逻辑、避免潜在错误,并优化数据转换流程,确保程序的健壮性和灵活性。 引言:map方法与数…

    2025年12月21日
    000
  • JavaScript数组对象转换:按指定键分组与值收集

    本文将深入探讨如何在javascript中将扁平化的对象数组转换为按特定键分组的新对象。通过实例代码,我们将详细介绍两种核心实现策略:传统的`for…of`循环迭代和现代的`array.prototype.reduce()`方法。文章将比较这两种方法的特点、适用场景及性能考量,帮助开发者…

    2025年12月21日
    000
  • 深入理解JavaScript Promise异步执行与微任务队列

    本文深入探讨javascript中promise的异步执行机制,特别是其与事件循环和微任务队列的交互。通过一个具体代码示例,我们将逐步分析promise链中`then`回调函数的入队、出队及执行顺序,揭示`console.log`输出背后的原理,帮助开发者掌握promise的执行时序。 JavaSc…

    2025年12月21日
    000
  • JavaScript生成器_javascript异步迭代

    生成器函数通过function*定义,使用yield暂停执行并按需产出值,适合处理大量或无限数据;结合async可创建异步生成器,支持在yield中使用await,实现对异步数据源的惰性求值。通过实现Symbol.asyncIterator接口,对象可被for await…of遍历,适用…

    2025年12月21日
    000
  • CP-ABE在Node.js与区块链应用中的实现路径探究

    CP-ABE在Node.js和区块链项目中的实现面临JavaScript库稀缺的挑战。本文将探讨当前主流的CP-ABE库生态,指出Python、C++和Rust等语言中的成熟解决方案,并讨论Node.js绑定及Go语言库作为替代方案的可行性,为开发者提供跨语言集成的策略与建议,以克服JavaScri…

    2025年12月21日
    000
  • 如何使用Octokit高效查询GitHub组织下所有仓库的开放PR

    本文详细介绍了如何利用Octokit库通过单个API请求,高效地查询GitHub组织下所有仓库的开放Pull Request。针对传统API需指定仓库名的限制,教程将重点阐述使用`GET /search/issues`端点结合特定查询参数`q: ‘is:pr is:open org:OR…

    2025年12月21日
    000
  • JavaScript中赋值与自增运算符的复杂交互与执行机制

    本文深入探讨了JavaScript中赋值运算符(如`+=`)与自增运算符(如`++`)在复杂表达式中的交互与执行顺序。文章详细解析了ECMAScript规范中关于左侧表达式优先评估、右侧表达式求值以及最终赋值的机制,并通过具体代码示例,逐步拆解了包含多重副作用的表达式,揭示了变量值在不同阶段的变化,…

    2025年12月21日
    000
  • 处理嵌套交互式控件:前端可访问性指南

    本教程深入探讨了在web开发中,尤其是使用axe dev tool进行可访问性测试时,常见的“交互式控件不得嵌套”错误。文章将解释为何在可点击的表格行中嵌套复选框会引发此问题,分析其对用户体验和可访问性的影响,并提供具体的解决方案,包括利用事件传播机制来优化交互逻辑,确保符合可访问性标准。 理解“嵌…

    2025年12月21日
    000
  • JavaScript DOM操作:高效清空列表元素的策略与实践

    本教程探讨了在javascript中清空dom列表元素的高效方法,旨在解决传统for循环在迭代和修改dom时常遇到的问题。我们将介绍两种推荐策略:利用innerhtml = “”实现快速清空,以及通过queryselectorall结合foreach循环进行精确删除,帮助开发…

    2025年12月21日
    000
  • 解决Tabulator日期时间排序问题的专业指南

    本文旨在解决tabulator表格组件在处理包含时间信息的日期字符串时排序不准确的问题。通过深入探讨默认排序机制的局限性,并提供两种有效的解决方案:首先是检查并调整排序方向(`dir`参数),其次是利用javascript的`date`对象实现自定义排序器。文章将提供详细的代码示例和实现步骤,帮助开…

    2025年12月21日
    000
  • 深入理解Promise链:如何在catch后中断then的执行

    在JavaScript Promise链中,`.catch()`默认行为是返回一个已解决的Promise,这可能导致后续的`.then()`块意外执行。本文将深入探讨这一机制,并提供两种核心策略来实现在`.catch()`处理错误后,有效中断Promise链,避免后续`.then()`块的执行,确保…

    2025年12月21日
    000
  • 解决 Express.js 中 PUT 请求密码修改失败的路由配置指南

    本文深入探讨了在 express.js 应用中使用 put 请求修改用户密码时遇到的常见“500 – internal server error”问题。核心问题在于 put 请求的路由定义,它通常需要包含一个资源标识符(如 `/:id`)。文章将详细解释为何添加此参数能解决路由匹配失败的…

    2025年12月21日
    000
  • React列表渲染与独立状态管理:避免全局状态影响局部更新

    本文探讨了在react中处理列表项独立状态的常见问题,即当点击单个列表项时,如何避免所有项同时响应。通过将状态(如选中状态)直接嵌入到每个列表项的数据对象中,并采用不可变更新策略,可以确保每个列表项拥有独立的行为和视觉反馈,从而实现精确的局部状态管理。 在React应用中,当我们需要渲染一个列表(例…

    2025年12月21日
    000
  • JavaScript数据结构转换:将对象数组按类别分组

    本文将探讨如何将包含多个对象的javascript数组转换为按特定属性(如类别)分组的对象。我们将介绍两种高效且常用的方法:使用`for…of`循环进行迭代处理,以及利用`array.prototype.reduce()`实现更函数式的转换。通过这两种方法,读者可以灵活地将扁平化的数据结…

    2025年12月21日
    000
  • 如何使用Node.js csv 包按条件移除含空字段的CSV记录

    本教程将指导您如何在使用node.js的`csv`包解析csv文件时,有效过滤并移除那些包含任何空字段的记录。通过结合`cast`函数将空值转换为`undefined`,并在解析后利用数组的`filter`方法进行二次筛选,您可以精确控制数据清洗过程,确保最终数据集的完整性和准确性,避免了`skip…

    2025年12月21日
    000
  • JavaScript中高效清空DOM列表元素:解决for循环中断与任务管理问题

    本文旨在解决javascript中清空dom列表元素时遇到的常见问题,特别是`for`循环难以正确中断和导致新任务无法添加的困境。我们将深入探讨两种高效且推荐的解决方案:利用`innerhtml = “”`属性快速清空容器内容,以及通过`queryselectorall`获取…

    2025年12月21日
    000
  • JavaScript中如何高效提取对象指定属性

    本文详细介绍了在JavaScript中,如何利用`Object.entries()`、`Array.prototype.filter()`和`Object.fromEntries()`这三个现代JavaScript特性,从一个现有对象中高效且优雅地提取出指定的一组属性,生成一个新的对象。文章涵盖了从…

    2025年12月21日
    000
  • 数据可视化实战_javascript图表库

    答案:本文介绍了Chart.js、D3.js和ECharts三大JavaScript图表库。Chart.js轻量易用,适合快速开发;D3.js灵活强大,适合高度定制;ECharts功能全面,适用于复杂场景。根据项目需求选择合适的库可提升数据可视化效果和用户体验。 在现代Web开发中,数据可视化已成为…

    2025年12月21日
    000
  • JavaScript元编程_Symbol与反射API应用

    Symbol和Reflect提供元编程能力,Symbol创建唯一键避免属性冲突,可用于定义私有属性或自定义对象行为如迭代;Reflect配合Proxy实现对象操作拦截,用于只读代理、日志监控等场景,二者结合提升代码抽象层级与控制力。 JavaScript 的元编程能力让开发者可以更灵活地控制对象的行…

    2025年12月21日
    000

发表回复

登录后才能评论
关注微信