JavaScript设计模式-工厂设计模式(1)

简介: JavaScript设计模式-工厂设计模式(1)

什么是设计模式


设计模式是一种编程思想或者是代码管理的思想,基于不同的设计模式可以帮助我们解决某些特定问题,也可以理解成一些问题的解决方案,我们使用设计模式的目的在于使得我们编写代码实现“高内聚”和“低耦合”,设计模式也可以让我们编写的代码提高性能,提升我们开发的效率;

工厂设计模式


工厂设计模式对应的是我们生活中常见的工厂,对一类相同的产品实现制造,打包,出厂等操作,工厂设计模式也是如此,工厂设计模式需要配合其构造函数结合new关键字进行实现,单独使用构造函数实现会出现问题

没使用new关键字


工厂设计模式其实就是一个闭包的操作,每个由工厂生产出来的数据,不同之处在于内存地址不同

function Fn() {
    function main() {
        console.log('...工厂模式');
    };
    // 添加原料
    let obj = {};
    // 加工原料
    obj.fn = main;
    obj.v = 1;
    // 出厂
    return obj;
};
function Page() {
    let obj = {};
    obj.v = 1;
    // 出厂
    return obj;
};
//调用工厂函数
let a1 = Fn();
let b1 = Fn();
let page = Page();
// 调用工厂函数返回的函数
a1.fn();
b1.fn();
console.log('a1当前的构造函数', a1.constructor); //Object
console.log('page当前的构造函数', page.constructor); //Object
console.log('对象的比较', a1.fn === b1.fn); //false,
/**
对象比较的有俩个条件
1.地址一样
2.内容一样,这里表现出了,就是当前的函每创建一次就执行一次,创建一个函数进行挂载
**/

以上没有采用new关键字使用构造函数创建出来的数据存在以下几个问题

  1. 对象识别问题,现在有俩个工厂一个是Fn一个是Page,现在的a1虽然是调用的Fn,但是他不知道他是属于Fn工厂的还是page工厂的,page也是一样的,constructor返回对创建此对象的函数
  2. 性能问题,就是说当前的函数每执行一次就要调用一次,就有又开辟出来一块空间

这里我们可以采用new关键字进行解决目前所遇到的问题

使用new关键字


我们首先要知道new关键字做了那些事情

  1. 执行函数;
  2. 自动创建一个空对象;
  3. 把创建的对象指向另外一个对象;
  4. 把空对象和函数里的this 衔接起来;(this指向实例化对象)
  5. 隐式返还this;
function Tab(name = '前端若水', age = '20') {
//由于new运算符会帮我们自动创建空对象所以免得创建了,由于new运算符会帮我们把空对象和this链接起来所以可以不用对象名直接用this
    this.name = name;
    this.age = function() {
            console.log(`我是${this.name},今年${age}岁!`);
        }
        // 由于new运算符会隐式返还this,所以我们不需要去return
};
// 使用构造函数
let a1 = new Tab();
let a2 = new Tab();
// 使用构造函数的方法
a1.age();
/*会有一个公共空间prototype原型,他会去开辟一个空间去存放我们的方法,prototype和__proto__是一样的 */
Tab.prototype.psf = function() {
        console.log(`原型方法`);
    }
    // 如果是未使用new 关键字,调用多少次,就开辟出多少个函数内存进行执行,但是使用了new关键字,把方法挂载在了prototype上面,这样的话,函数就放在了公共空间里面
console.log(`同一个构造函数,且挂载到了peototype上的方法${a1.psf===a2.psf}`);
// 这样没有挂载的,函数每执行一次就创建一个空间,但是挂载到原型上面的就只会创建一个空间,更节约性能
console.log(`同一个构造函数,没有挂载的方法${a1.age===a2.age}`);
// 查看当前的构造函数是哪个
console.log(a1.constructor);

使用new关键字就可以轻松解决工厂模式的对象识别问题和性能问题,所以工厂设计模式是需要使用构造函数结合new关键字进行实现的!

坚持努力,无惧未来!

相关文章
|
4月前
|
设计模式 JavaScript 前端开发
js设计模式【详解】—— 职责链模式
js设计模式【详解】—— 职责链模式
77 8
|
4月前
|
设计模式 JavaScript 前端开发
js设计模式【详解】—— 组合模式
js设计模式【详解】—— 组合模式
52 7
|
1月前
|
设计模式 JavaScript 前端开发
JavaScript设计模式--访问者模式
【10月更文挑战第1天】
31 3
|
3月前
|
设计模式 JavaScript 前端开发
从工厂到单例再到策略:Vue.js高效应用JavaScript设计模式
【8月更文挑战第30天】在现代Web开发中,结合使用JavaScript设计模式与框架如Vue.js能显著提升代码质量和项目的可维护性。本文探讨了常见JavaScript设计模式及其在Vue.js中的应用。通过具体示例介绍了工厂模式、单例模式和策略模式的应用场景及其实现方法。例如,工厂模式通过`NavFactory`根据用户角色动态创建不同的导航栏组件;单例模式则通过全局事件总线`eventBus`实现跨组件通信;策略模式用于处理不同的表单验证规则。这些设计模式的应用不仅提高了代码的复用性和灵活性,还增强了Vue应用的整体质量。
52 1
|
3月前
|
设计模式 XML 数据格式
python之工厂设计模式
python之工厂设计模式
python之工厂设计模式
|
3月前
|
设计模式 JavaScript 前端开发
小白请看 JS大项目宝典:设计模式 教你如何追到心仪的女神
小白请看 JS大项目宝典:设计模式 教你如何追到心仪的女神
|
3月前
|
设计模式 测试技术
依赖注入与工厂设计模式的区别
【8月更文挑战第22天】
60 0
|
4月前
|
设计模式 JavaScript Go
js设计模式【详解】—— 状态模式
js设计模式【详解】—— 状态模式
80 7
|
4月前
|
设计模式 JavaScript
js设计模式【详解】—— 桥接模式
js设计模式【详解】—— 桥接模式
71 6
|
4月前
|
设计模式 JavaScript
js设计模式【详解】—— 原型模式
js设计模式【详解】—— 原型模式
50 6

热门文章

最新文章

  • 1
    C++一分钟之-设计模式:工厂模式与抽象工厂
    43
  • 2
    《手把手教你》系列基础篇(九十四)-java+ selenium自动化测试-框架设计基础-POM设计模式实现-下篇(详解教程)
    48
  • 3
    C++一分钟之-C++中的设计模式:单例模式
    58
  • 4
    《手把手教你》系列基础篇(九十三)-java+ selenium自动化测试-框架设计基础-POM设计模式实现-上篇(详解教程)
    38
  • 5
    《手把手教你》系列基础篇(九十二)-java+ selenium自动化测试-框架设计基础-POM设计模式简介(详解教程)
    63
  • 6
    Java面试题:结合设计模式与并发工具包实现高效缓存;多线程与内存管理优化实践;并发框架与设计模式在复杂系统中的应用
    58
  • 7
    Java面试题:设计模式在并发编程中的创新应用,Java内存管理与多线程工具类的综合应用,Java并发工具包与并发框架的创新应用
    42
  • 8
    Java面试题:如何使用设计模式优化多线程环境下的资源管理?Java内存模型与并发工具类的协同工作,描述ForkJoinPool的工作机制,并解释其在并行计算中的优势。如何根据任务特性调整线程池参数
    50
  • 9
    Java面试题:请列举三种常用的设计模式,并分别给出在Java中的应用场景?请分析Java内存管理中的主要问题,并提出相应的优化策略?请简述Java多线程编程中的常见问题,并给出解决方案
    110
  • 10
    Java面试题:设计模式如单例模式、工厂模式、观察者模式等在多线程环境下线程安全问题,Java内存模型定义了线程如何与内存交互,包括原子性、可见性、有序性,并发框架提供了更高层次的并发任务处理能力
    78