javascript如何才能脱离函数式编程,拥抱面向对象编程呢,常见的有3种形式,其它形式可以说都是这3种的变种。
 
1.直接定义对象直接量的形式
 
var Util={
    getType:function(obj){
    return Object.prototype.toString.call(obj).replace(/^\[object (.+)\]$/, '$1').toLowerCase();
    }
}
这种是最简单的封装形式,不需要用到原型,也不需要构造器函数,当你只需要一个对象实例的时候,例如一个工具类
调用形式也不需要使用new,直接的Util.getType(obj);
 
 
2.构造器函数this绑定对象形式
 
var User=function (){
    this.userName="windy";
    this.eat=function(){
      console.log("i'm eatting");
   } 
    this.sleep=function(){
      console.log("i'm sleeping")
   }
}
这种定义方式不需要用到对象原型,调用的时候需要用到new 操作符,var user=new User();
需要特别注意的是this的指向问题,this并不是指向User构造器函数的,在调用new User()时生成了一个空对象,
先不考虑原型,简单的理解相当于调用了var obj={}; User.apply(obj,arguments);
这种方式每次调用一次new ,都会把通过this.定义的属性和函数全部拷贝一次,虽然对于function来说只是拷贝了引用,只多占了少许内存,但对于像jquery这种有成百上千个实例,方法数量又很多的情况下浪费就比较大了。
 
因此最优的形式是第3种,原型的方式定义
 
3.构造器函数原型对象定义形式
var User=function (){
    this.userName="windy";
    User.prototype.eat=function(){
      console.log("i'm eatting");
   } 
    User.prototype.sleep=function(){
      console.log("i'm sleeping")
   }
}

原则上是将属性定义在新生成的对象上,将函数定义在原型上,私有变量用var声明,这样新生成的对象就只包含属性,方法都通过原型链引用,不会污染当前对象。不过像上面这段代码这样定义,一旦需要改类(对象)的名字很麻烦,每个方法都要硬编码User对象,好多重复啊,

 
改进后:
var User=function (){
    this.userName="windy";
    User.prototype={
      constructor:User,
     eat:function(){
      console.log("i'm eatting");
   } ,
     sleep:function(){
      console.log("i'm sleeping")
   }
    }
}
 
直接给prototype赋值会造成construcor丢失,因为construtor是取原型上的该属性的,如果直接覆盖原型就没这个引用了,所以要单独再赋值回来,当然如果你要不需要用到constructor的话不赋值也没关系。
 
但还是出现了两个User的硬编码,再进一步可以用var FN=arguments.callee;  FN.prototype={......}
 
 
总结:2和3两种形式都会返回一个自动创建的新对象,不同的是前者是将方法都定义在了新对象上,而后者并没有把方法定义在新对象上,而是对构造器函数的原型开刀,定义在原型上,生成的新对象虽然啥都没有,但是通过__proto__原型链访问到构造函数的原型就拥有了一切。
 
另外,在构造器函数中是会自动return 新对象的,但是如果手动定一个return ,则会返回手工定义的对象,这个手工定义的对象原型也是赋值为该构造器函数,如果return的是原始值类型(string,number,boolean),则这个return 会被无视。
 

javascript面向对象编程的3种常见封装形式解析的更多相关文章

  1. 转:javascript面向对象编程

    作者: 阮一峰 日期: 2010年5月17日 学习Javascript,最难的地方是什么? 我觉得,Object(对象)最难.因为Javascript的Object模型很独特,和其他语言都不一样,初学 ...

  2. (二)Javascript面向对象编程:构造函数的继承

    Javascript面向对象编程:构造函数的继承   这个系列的第一部分,主要介绍了如何"封装"数据和方法,以及如何从原型对象生成实例. 今天要介绍的是,对象之间的"继承 ...

  3. Javascript面向对象编程(二):构造函数的继承 作者:yuan一峰

    Javascript面向对象编程(二):构造函数的继承   作者: 阮一峰 日期: 2010年5月23日 这个系列的第一部分,主要介绍了如何"封装"数据和方法,以及如何从原型对象生 ...

  4. JavaScript面向对象编程[转]

    JavaScript面向对象编程 命名空间 命名空间是一个容器,它允许开发人员在一个独特的,特定于应用程序的名称下捆绑所有的功能. 在JavaScript中,命名空间只是另一个包含方法,属性,对象的对 ...

  5. javascript 面向对象编程(工厂模式、构造函数模式、原型模式)

      javascript 面向对象编程(工厂模式.构造函数模式.原型模式) CreateTime--2018年3月29日17:09:38 Author:Marydon 一.工厂模式 /** * 工厂模 ...

  6. JavaScript 面向对象编程(二):继承

    Javascript面向对象编程(二):构造函数的继承 这个系列的第一部分,主要介绍了如何"封装"数据和方法,以及如何从原型对象生成实例. 今天要介绍的是,对象之间的"继 ...

  7. 快速学习JavaScript面向对象编程

    到处都是属性.方法,代码极其难懂,天哪,我的程序员,你究竟在做什么?仔细看看这篇指南,让我们一起写出优雅的面向对象的JavaScript代码吧! 作为一个开发者,能否写出优雅的代码对于你的职业生涯至关 ...

  8. 深入理解Javascript面向对象编程

    深入理解Javascript面向对象编程 阅读目录 一:理解构造函数原型(prototype)机制 二:理解原型域链的概念 三:理解原型继承机制 四:理解使用类继承(继承的更好的方案) 五:建议使用封 ...

  9. 【转】Javascript 面向对象编程(一):封装

    原文链接:http://www.ruanyifeng.com/blog/2010/05/object-oriented_javascript_encapsulation.html Javascript ...

随机推荐

  1. docker幕布笔记

    幕布链接>>>>https://mubu.com/doc/l_KDT3S5w0

  2. Java中很少用的CopyOnWriteArrayList

    类注释 /** * A thread-safe variant of {@link java.util.ArrayList} in which all mutative * operations ({ ...

  3. 视频编解码 基本概念:GOP

    前言 产品开发要求添加视频剪辑功能,翻阅有关的文档,查到了GOP(group of pictures)这个概念. 解析 GOP说白了就是两个I帧之间的间隔.比较说GOP为120,如果是720p60的话 ...

  4. GNS3 模拟icmp重定向

    网关实质上是一个网络通向其他网络的IP地址.比如有网络A和网络B,网络A的IP地址范围为“192.168.1.1~192. 168.1.254”,子网掩码为255.255.255.0:网络B的IP地址 ...

  5. 如何修改 app.config 的配置信息

    如何修改 app.config 的配置信息 收藏 最问这个问题的人有点多,其实 .Net 提供了这样的功能我们可以在 app.config 中 userSettings 节点中保存我们的应用程序设置信 ...

  6. eclipse生成mybatis的逆向工程-mybatis代码自动生成

    首先,工作中一直在使用命令方式的mybatis的代码自动生成,今天把自己的笔记本直接搞一个在eclipse中生成的逆向代码生成工程,方便自己在家学习使用,在搞这个工程的过程中由于自己搞了一套环境,所i ...

  7. ROS常用库(四)API学习之常用common_msgs(下)

    一.前言 承接ROS常用库(三)API学习之常用common_msgs(上). 二.sensor_msgs 1.sensor_msgs / BatteryState.msg #电源状态 uint8 P ...

  8. bzoj 1138: [POI2009]Baj 最短回文路

    额,,貌似网上的题解都说超时之类的. 然而我这个辣鸡在做的时候不知道在想什么,连超时的都不会. 超时的大概是这样的,f[x][y]表示x到y的最短回文路,然后更新的话就是 f[x][y]更新到 f[a ...

  9. MongoDB首次启动常见问题

    问题1. exception in initandlisten 29 data directory /data/db not found 问题:MongoDB默认存储路径为/data/db,这里显示没 ...

  10. 052、Java中使用do…while循环实现1~100的累加

    01.代码如下: package TIANPAN; /** * 此处为文档注释 * * @author 田攀 微信382477247 */ public class TestDemo { public ...