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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 基于SSM框架的网上购物商城及电商后台管理系统

    基于SSM框架的网上购物商城及电商后台管理系统基于SSM框架的网上购物商城及电商后台管理系一、开发环境操作环境:Windows10开发工具:IDEA数据库:MySQL服务器:TomCat二、系统功能介绍前台商城功能注册登录:用户首先要填写相关信息,注册为会员。修改个人信息:用户登录后可以修改个人信息。查看公告和留言反馈网站:用户可查看公告,登录后可以给网站留言反馈网站问题。浏览商品:会员浏览网上商城,可以根据分类检索、关键字检索、热销商品和折扣商品浏览商品和商品信息及评价。管理购物车:登录后会员可以将想购买的商品加入购物

    2022年6月5日
    37
  • 说说你对servlet 的理解或者 servlet 是什么?「建议收藏」

    说说你对servlet 的理解或者 servlet 是什么?「建议收藏」说说你对servlet的理解或者servlet是什么?Servlet(ServletApplet),全称JavaServlet,是用Java编写的服务器端程序。而这些Servlet都要实现Servlet这个接口。其主要功能在于交互式的浏览和修改数据,生成动态Web内容。Servlet运行于支持Java的应用服务器中。 HttpServlet重写doGet和doPost

    2022年6月16日
    24
  • python提取字符串中的数字「建议收藏」

    python提取字符串中的数字「建议收藏」一、isdigit()函数isdigit()函数是检测输入字符串是否只由数字组成。如果字符串只包含数字则返回True否则返回False。dream=”123456″print(dream.isdigit())#返回:Truedream=”123abc456″print(dream.isdigit())#返回:Falsedream=’abcd’print(dream.isdigit())#返回:False二、filter()函数说明:filter()函

    2022年10月10日
    0
  • vue 文件上传至服务器_oss文件服务器

    vue 文件上传至服务器_oss文件服务器为什么使用对象存储OSS很多企业的文件上传下载都是通过文件流的形式进行上传下载的,需要后端配合,对服务器压力很大,而且高消费,对公司损失太大,我们选择使用oss将尽可能地缩小成本,以及对网站及逆行大幅度提升使用对象存储OSS改变了什么网站数据动静分离,大幅提升网页性能 单独的文件管理界面,管理网站文件和本地电脑一样高效率方便使用 成本低,资源弹性伸缩,按需付费什么是对象存储OSS阿里云对象存储OSS(ObjectStorageService)是一款海量、安全、低成本、高可靠的云存储

    2022年8月15日
    4
  • Window永久关闭默认共享

    windows默认共享你如果是在这里关闭的,开机之后默认共享文件夹又是打开的。管理工具—计算机管理—共享文件夹–共享下面介绍一种简单的永久关闭默认共享文件夹。1.找到window的开机自启动文件夹,注:这是所有用户登录都会开机自启动文件夹。C:\ProgramData\Microsoft\Windows\StartMenu\Programs\StartUp2.创建一个bat脚本,然后开机就能自动关闭默认共享文件夹。…

    2022年4月7日
    52
  • 淘宝自动抢购脚本「建议收藏」

    淘宝自动抢购脚本「建议收藏」淘宝自动抢购脚本抢购脚本是通过Selenium来完成自动登录,和自动点击的操作的。Selenium是一个用于Web应用程序测试的工具,Selenium可以直接运行在浏览器中,通过后台控制操作浏览器,完成购买操作。教程需要安装python环境,安装python环境可参考链接安装python完后记得配置环境和安装Pycharm编辑器(安装Pycharm可参考)一、安装Selenium库Selenium模块是Python的第三方库,可以通过pip进行安装:pip3installselen

    2022年4月29日
    632

发表回复

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

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