JS学习笔记-OO创建怀疑的对象

JS学习笔记-OO创建怀疑的对象

大家好,又见面了,我是全栈君,今天给大家准备了Idea注册码。

问了、工厂介绍,解决重码

        前面已经提到,JS中创建对象的方法。不难发现,主要的创建方法中,创建一个对象还算简单,假设创建多个类似的对象的话就会产生大量反复的代码。

 

        解决:工厂模式方法(加入一个专门创建对象的方法,传入參数避免反复)

        

         function createObject(name,age){
                  var obj =new Object();         //创建对象
                  obj.name = name;
                  obj.age = age;
                  obj.run = function(){
                          return this.name + this.age + '处理中...';
                  };
                  return obj;        //返回对象引用
         };

 

问二、引入构造函数,解决对象识别

        上面方法尽管攻克了避免反复代码出现的问题。但也带来了无法识别详细对象的问题,方法内部使用new Object的方式,最后返回该对象引用,调用该方法创建的对象返回的所有都是Object的引用。因此使用typeofinstanceof操作符时都无法区分详细对象。

        解决:构造函数(改良后的工厂方法)

         function Box(name,age){    //创建对象                  this.name = name;                  this.age = age;                  this.run = function(){                          return this.name + this.age + '处理中...';                  };         };

 

        比較:细心的童鞋就该发现了,该方法与问一中的工厂模式不同之处就在于:省略了newObject()的明文运行过程;省略了return语句,这些都由后台自己主动运行。

        而构造函数差别普通函数的地方在于其调用方式,必须用new运算符或对象冒充方式调用。

 

问三、引入prototype属性对象。解决对象之间的共享问题

        每个对象都会有一个prototype,同一时候它也是一个对象。

使用目的是为了解决共享问题,调用同一个构造函数创建的该对象会共享prototype中的属性和方法。

        解决:使用原型模式解决共享

         function Box() {} //声明一个构造函数                  Box.prototype.name = 'Lee'; //在原型里加入属性                  Box.prototype.age = 100;                  Box.prototype.run = function () { //在原型里加入方法                  return this.name + this.age + '处理中...';         };

        比較:  

构造函数创建

JS学习笔记-OO创建怀疑的对象

使用原型创建

JS学习笔记-OO创建怀疑的对象

        细节:在调用属性或方法时,採用就近原则。先查找实例中是否存在,否的话查找原型。可使用isPrototypeOf()hasOwnPrototy(),in操作符进行相关測试。

 

问四、使用组合,解决共享及传參

        原型模式创建对象省略了构造函数传參初始化的过程,这既是它的缺点又是它的长处,缺点是对象初始化的值一样,而且假设原型属性中包括有引用类型,则对一个对象进行更改。其它对象的相应属性也会跟着更改了。

        解决:组合构造函数+原型模式(解决共享和传參的问题)

         function Box(name, age) {          //不共享的使用构造函数                  this.name = name;                  this.age = age;                  this. family = ['父亲', '母亲', '妹妹'];         };         Box.prototype = {                  //共享的使用原型模式                  constructor : Box,                  run : function () {                           return this.name + this.age + this.family;                  }         };

        细节:这样的方式事实上就是将构造函数与原型一起使用。对要创建的对象分析,将须要共享的内容放入原型中,不须要的则放在构造函数里。这样也就是组合了。

        

        优化:这样分开式的写法难免有些怪异。我们将这两部分合并

        动态原型模式(第一次调用共享方法时进行初始化原型。以后就不会初始化了)

         function Box(name ,age) { //将全部信息封装到函数体内                  this.name = name;                  this.age = age;                  if (typeof this.run != 'function') {//仅在第一次调用的初始化                           Box.prototype.run = function () {                                   return this.name +this.age + '处理中...';                           };                  }         }

 

中结:

        学习JS中,还是非常须要对正统面向对象语言的理解的,在这里我们学习了使用构造函数以及原型来创建对象,理解了二者的概念,对于后面的JS中面向对象深入学习会非常有帮助。创造出各种不同的方法来解决的不同情况下的问题,了解按需这些人才。

版权声明:本文博主原创文章,博客,未经同意不得转载。

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

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/117101.html原文链接:https://javaforall.net

(0)
上一篇 2022年1月10日 下午8:00
下一篇 2022年1月10日 下午9:00


相关推荐

  • linux export命令找不到_docker执行容器内的shell

    linux export命令找不到_docker执行容器内的shellLinuxexport命令用于设置或显示环境变量。在shell中执行程序时,shell会提供一组环境变量。export可新增,修改或删除环境变量,供后续执行的程序使用。export的效力仅及于该次登陆操作。语法export[-fnp][变量名称]=[变量设置值]参数说明:-f 代表[变量名称]中为函数名称。 -n 删除指定的变量。变量实际上并未删除,只是不会输出到后…

    2025年9月29日
    6
  • Java后台接收参数出现java.lang.Integer cannot be cast to java.lang.Double错误(已解决)[通俗易懂]

    Java后台接收参数出现java.lang.Integer cannot be cast to java.lang.Double错误(已解决)[通俗易懂]在Java接受前端传过来的数据信息的时候,使用List<List<double>>进行接收结果出现这个错误java.lang.Integercannotbecasttojava.lang.Double是类型转换出现的错误,当是这个数据在前端明明处理过,使用parseFloat转为了浮点数后端使用List<List>进行接收,此时也没有报错于是打开debug进行调试检查问题,发现传过来的数值如果是整数则为Integer类型,有小数的才是double类型

    2022年7月16日
    21
  • RadControls for ASP.NET Ajax 笔记(1)

    RadControls for ASP.NET Ajax 笔记(1)(1)遍历Grid中的所有Item(一行),一次仅展开一行【Singleexpandinhierarchicalgrid】privatevoidRadGrid1_ItemCommand(objectsource,Telerik.Web.UI.GridCommandEventArgse){if(e.CommandName==RadGrid.ExpandCo…

    2022年7月19日
    16
  • ssh配置免密码登录(linux免密登录)

    由于公司的生产环境有很多台Linux的CentOS服务器,为了方便机子(假设两台机子A,B)互相之间免密ssh,scp命令操作,配置如下1.在A、B上分别创建本机的公钥和私钥,输入命令后连续三次回车ssh-keygen-trsa2.查看公私钥的文件生成情况cd~/.ssh/ls看到列表有2个文件:文件说明:id_rsa:生成的私钥文件id_rsa.pub:生成的公钥文件3….

    2022年4月14日
    36
  • 进程及进程控制块「建议收藏」

    进程及进程控制块「建议收藏」进程是程序的一个执行实例,是一个正在执行的程序。能分配处理器并由处理器执行的实体。     在一个系统上可以同时运行多个程序。并发运行,一个进程的指令和另一个进程的指令是交错执行的。     进程的两个基本元素是程序代码(可能被执行相同程序的其他进程共享)和代码相关联的数据集。进程是一种动态描述,但并不代表所有的进程都在运行(进程在内存中因策略或调度需求,会处于各种状态)。

    2025年7月22日
    5
  • mysql乐观锁实现

    mysql乐观锁实现各锁的概念 悲观锁 假定会发生并发冲突 屏蔽一切可能违反数据完整性的操作悲观锁 从字面理解就是很悲观 每次去拿数据的时候都认为别人会修改 所以在每次拿的时候对数据上锁 这样就保证了数据的准确性 比如 mysql 中的表锁 行锁 表锁 当你对一张表进行修改时 会锁死整张表 其他的请求需要在修改完成释放锁才能继续 在高并发的情景下不适用 行锁 当你对一张表的某一行数据修改时 会锁死这一行数

    2026年3月26日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号