JavaScript工厂模式、原型模式、构造器模式

一.什么是模式.模式是一种可复用的解决方案,而反模式呢就是针对某个问题的不良解决方案。

js反模式常见例子

①向setTimeout和setInterval传递字符串,而不是函数,这会触发eval()的内部使用。
②在全局上下文中定义大量的变量污染全局命名空间
③修改Object类的原型
④以内联形式使用js,嵌入在HTML文件中的js代码是无法包含在外部单元测试工具中的。

⑤滥用document.write,如果在页面加载完成后执行docume.write,它会重写我们所在的页面,可以使用document.creatElement代替的话就尽量不用docume.write。

二.设计模式的类别

(一).工厂(Factory)模式(简单与复杂)

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

简单来说就是封装后的代码,简单的工厂模式是很好理解的,关于它的作用,就是利用面向对象的方法,把一些对象封装,使一些占用空间多的,重复的代码封装起来。实现方法非常简单,也就是在函数内创建一个对象,给对象赋予属性以及方法再将对象返回即可。这种方法 就是为了解决实例化对象产生大量重复的问题

function creatper(name,age){  var per=new Object(); //原料//加工per.name=name;per.age=age;  per.sayHi=function(){  console.log(per.name+'已经有'+per.age+"岁");  }return per; //出厂}var test1=creatper('lili',22);var test2 =creatper('mike',25);//第二个实例test1.sayHi();test2.sayHi();console.log(test1.name);

登录后复制

可以看出,使用工厂模式,可以重复调用这个per函数来生成不同属性值得对象,这就像工厂一样,批量生产,里面的原料,加工,出厂都很清晰。但是你会发现工厂模式是无法识别对象的类型,因为全都是object,不像Date,Array等。

何时使用工厂模式?
Factory模式主要在以下场景使用:
①当对象或组件涉及高复杂性时
②当需要根据所在的不同环境轻松生成对象的不同实例时

③当处理很多共享相同属性的小型对象或组件时

(二).构造器(Constructor)模式

ECMAScript 中可以采用构造函数(构造方法)可用来创建特定的对象。 该模式正好可以解决以上的工厂模式无法识别对象实例的问题。

function Student(name,age,classa){//构造函数模式        this.name = name;        this.age = age;        this.classa = classa;        this.run = function () {            console.log(this.name+ this.age+ "岁上"+this.classa +"!");        }    }    var Benz = new Student('Lili',22,'初三');    var BMW = new Student("Mike",25,"初一");    console.log(Benz instanceof Student); //很清晰的识别他从属于Student    Benz.run();    BMW.run();

登录后复制

由代码可以看出,于工厂模式除了函数名不同以外,a.构造函数方法没有显示的创建对象 (new Object()),b.直接把属性和方法赋值给了this对象,c.没有return语句。能够识别对象(这正是构造函数模式胜于工厂模式的地方)。注意补充:构造函数的方法规范:1.函数名和实例化构造名相同且大写2.通过构造函数创建对象,必须使用 new 运算符。

既然通过构造函数可以创建对象,那么这个对象是哪里来的, new Object()在什么地方执行了?执行的过程如下:
1.当使用了构造函数,并且 new 构造函数(),那么就后台执行了 new Object();
2.将构造函数的作用域给新对象 ,(即 new Object()创建出的对象),而函数体内的 this 就 代表 new Object()出来的对象。
3.执行构造函数内的代码; 

4.返回新对象(后台直接返回)。 

(三).原型模式

js规定每一个创建的函数都有prototype(原型)属性,这个属性是指针,指向一个对象,而这个对象的用途是包含由特定类型的所有实例所共享的属性和方法,使用原型对象就可以让所有实例对象均包含这些属性及方法。

function Per(){}Per.prototype.name='小米';Per.prototype.age=22;Per.prototype.course=['php','javascript','java','C#'];Per.prototype.say=function(){console.log(this.name+"有"+this.age+"岁,学习了"+this.course+"等课程。");}var per1=new Per();var per2=new Per();per1.name='小林';per1.course.push('Html5');per1.say();per2.say();per2.course.pop();

登录后复制

关于原型模式的缺点,我想也是很明显的,它省略了构造函数传递初始化参数这一环节,结果所有实例均在默认情况下取得了相同的属性值,虽然你可以在后来做出更改,但一点都不方便,这样还不是最大的问题,原型模式最大的问题是在于共享的本性所导致的,由于共享,因此一个实例修改了引用,另一个也随之更改了属性。因此一般不会单独使用原型模式。

(四).带原型的Constructor(构造器)= 原型模式+构造器模式

function Per(name,age,course){this.name=name;this.age=age;this.course=course;}Per.prototype.say=function(){console.log(this.name+"有"+this.age+"岁,学习了"+this.course+"等课程。");}var per1=new Per('Make',22,['C#','java','PHP','Javascript']);var per2=new Per('小高',21,['oracle','mysql','nodejs','html5']);per1.say();//Make有22岁,学习了C#,java,PHP,Javascript等课程。per2.say();//小高有21岁,学习了oracle,mysql,nodejs,html5等课程。per1.course.pop();per1.say();//Make有22岁,学习了C#,java,PHP等课程。per2.say();//小高有21岁,学习了oracle,mysql,nodejs,html5等课程。

登录后复制

从上面分析:构造函数用于定义实例的属性,而原型模式用于定义方法和一些共享的属性。每个实例都会有自己的属性,但同时又共享着方法,最大限度的节省了内存。另外这种模式还支持传递初始参数。使用最广泛。

相关推荐:

JS设计模式之原型模式详解

JS设计模式之命令模式详解

JS设计模式之代理模式详解

以上就是JavaScript工厂模式、原型模式、构造器模式的详细内容,更多请关注【创想鸟】其它相关文章!

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

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2781258.html

(0)
上一篇 2025年3月8日 16:14:41
下一篇 2025年2月28日 13:56:17

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • js高性能函数防抖与节流详解

    函数节流是指一定时间内js方法只跑一次,函数防抖:是指频繁触发的情况下,只有足够的空闲时间,才执行代码一次。本文主要和大家分享js高性能函数防抖与节流详解,希望能帮助到大家。 一.函数节流(throttle) 1.函数节流的目的例如,DOM…

    2025年3月8日
    200
  • JavaScript的json格式实例详解

    json的形式是用大括号“{}”包围起来的项目列表,每一个项目间用逗号(,)分隔,而项目就是用冒号(:)分隔的属性名和属性值。这是典型的字典表示形式,也再次表明javascript里的对象就是字典结构。不管多么复杂的对象,都可以用一句jso…

    2025年3月8日
    200
  • javascript常用工具类的封装总结

    本文主要和大家分享javascript常用工具类的封装总结,希望能帮助到大家。 一.javaScript 1. type 类型判断 isString (o) { //是否字符串    return Object.prototype.toSt…

    编程技术 2025年3月8日
    200
  • JavaScript正则表达式小技巧

    这次给大家带来JavaScript正则表达式小技巧,使用JavaScript正则表达式的注意事项有哪些,下面就是实战案例,一起来看一下。 正则表达式作为一种匹配处理字符串的利器在很多语言中都得到了广泛实现和应用.这篇文章主要介绍了JavaS…

    编程技术 2025年3月8日
    200
  • 原生js怎么调用json

    这次给大家带来原生js怎么调用json,原生js调用json的注意事项有哪些,下面就是实战案例,一起来看一下。 Ajax基础 ajax:无刷新数据读取,读取服务器上的信息 HTTP请求方法: GET:用于获取数据,如浏览帖子 ajax.ju…

    编程技术 2025年3月8日
    200
  • JavaScript中的数据截取问题详解

    本文主要和大家分享JavaScript中的数据截取问题详解,希望能帮助到大家。 一.数组中获取 1.获取value的值 var revokeModel = $(“#modalMsgRevoke form”).seri…

    2025年3月8日 编程技术
    200
  • JS实现默认头像填充

    这次给大家带来JS实现默认头像填充,JS实现默认头像填充的注意事项有哪些,下面就是实战案例,一起来看一下。 在我的不少项目中,都有缺省头像的问题。为了保持个性和方便辨认,会给没有头像的用户填充带名字的头像。 代码分享:https://git…

    2025年3月8日
    200
  • webpack打包指定JS文件需要怎么做

    这次给大家带来webpack打包指定JS文件需要怎么做,webpack打包指定JS文件的注意事项有哪些,下面就是实战案例,一起来看一下。 背景 最近接到一个需求,因为不确定打出的前端包所访问的后端IP,需要对项目中IP配置文件单独拿出来,方…

    编程技术 2025年3月8日
    200
  • JavaScript中字符串详解

    本文主要和大家分享javascript中字符串详解,希望能帮助到大家。 一.字符串基本 1.字符串的创建 基本的数据类型  String        var str = “字符串”; 引用的数据类型 String …

    编程技术 2025年3月8日
    200
  • JavaScript中的原型与原型链详解

    本文主要和大家分享javascript中的原型与原型链详解,说原型的时候,一般都是在说原型属性prototype。 一.介绍 1.函数的prototype属性 *所有的函数都有一个prototype属性,它默认指向一个object空对象(即…

    2025年3月8日 编程技术
    200

发表回复

登录后才能评论