JS中的对象定义方式,跟服务端,还是有很大差别的!

现在来说一下JS类的定义

工厂模式

function creatHeven(name,age){

  var temp =new Object();

  temp.age=age;

  temp.name=name;

  temp.say=function(){

    alert(this.name);

  };

  return temp;

}

var tempHeaven=creatHeaven('heaven','29');

大家可以看到工厂模式很简单,但是也有一些问题,它虽然解决了具有一些共性类的创建,但是我们无法知道当前创建的类是什么具体类型,只能知道是一个Object,例如不能知道 Date等;

为了解决这个问题,于是就有了构造函数模式创建类;

构造函数模式:

function CreatHeaven(name,age){

  this.name=name;

  this.age=age;

  this.say=function(){

    alert(this.name);

   };

}

var tempHeaven=new CreatHeaven('heaven',30);

大家看到,一些定义方式做了改变,类名称首字母也大写了,没有return,使用了new关键字;也能识别对象;

构造函数虽然好用,但是也是有缺点的,使用构造函数模式最大的缺点就是每次创建对象,都要创建方法,造成资源浪费,因此,我们可以将方法移到类外面,定义一个全局函数,但是这样看来并不像是一个类对象。

例如:

function say(){

  alert(this.name);

};

function CreatHeaven(name,age){

  this.name=name;

  this.age=age;

  this.say=say;

   };

}

var tempHeaven=new CreatHeaven('heaven',30);

这样做,显然失去了面向对象封装的意义,我们可以采用原型模式去创建一个对象;

原型模式:

我们创建的每个函数都有prototype原型属性,这个属相是一个指针,它指向一个对象;而这个对象的用途是包含可以由特定类型的所有实例共享的属性和方法。使用原型对象的好处就是可以让所有对象实例共享它所包含的属性及方法

function CreatHeaven(name,age){

  CreatHeaven.prototype.name=name;

  CreatHeaven.prototype.age=age;

  CreatHeaven.prototype.say=function(){

    alert(this.name);

   };

}

var tempHeaven1=new CreatHeaven('heaven1',30);

var tempHeaven2=new CreatHeaven('heaven2',30);

原型模式也有缺点,就是如果属性是一个对象,例如数组;这样在创建实例的时候,就是公用这个数组,数组内容改变了,其他实例都是指向这个数组,值也会跟着变。这是我们不想要的结果。

所以出现了,”原型模式+构造函数模式“  的方式创建类实例;

原型模式+构造函数模式:

function CreatHeaven(name,age){

  this.name=name;

  thsi.age=age;

  

}

CreatHeaven.prototype.say=function(){

   alert(this.name);

};

var tempHeaven1=new CreatHeaven('heaven1',30);

tempHeaven1.say();

var tempHeaven2=new CreatHeaven('heaven2',30);

tempHeaven2.say()

每个实例都会有自己的一份实例属性,但同时又共享着方法,最大限度的节省了内存。另外这种模式还支持传递初始参数。优点甚多。这种模式在ECMAScript中是使用最广泛、认同度最高的一种创建自定义对象的方法。

动态原型模式:

unction CreatHeaven(name,age){

  this.name=name;

  this.age=age;

  if(typeof this.say!='function'){

      CreatHeaven.prototype.say=function(){

           alert(this.name);

      };

  }

}

var tempHeaven1=new CreatHeaven('heaven1',30);

tempHeaven1.say();

var tempHeaven2=new CreatHeaven('heaven2',30);

tempHeaven2.say()

动态原型模式将所有信息封装在了构造函数中,而通过构造函数中初始化原型(仅第一个对象实例化时初始化原型),这个可以通过判断该方法是否有效而选择是否需要初始化原型。

总结:以上就是几个创建类实例的模式,根据具体需要选择哪个创建模式;推荐使用 ”原型模式+构造函数模式“,”动态原型模式“。

js对象定义的更多相关文章

  1. JS 对象定义

    JS 对象 JavaScript 中的所有事物都是对象:字符串.数值.数组.函数... 此外,JavaScript 允许自定义对象. JavaScript 对象 JavaScript 提供多个内建对象 ...

  2. js对象定义的最常用的三种方法

    定义对象:属性和方法的结合体(变量和函数的结合体) 1.(***)var obj = {} 2.var obj = new Object(); 3.使用function定义对象 具体例子分别为: // ...

  3. [JS] 面向对象的5种写法和拓展JS对象的写法

    面向对象的JAVA  最开始当然是对象的定义了 收集了以下的五种写法 //第1种写法 function Circle(r) { this.r = r; } Circle.PI = 3.14159; C ...

  4. javascript对象定义和操作

    //js对象定义有三种方式//js方法定义有三种方式 function fn(){} var fun = function(){} var fun = new function() {} //**** ...

  5. JavaScript学习12 JS中定义对象的几种方式

    JavaScript学习12 JS中定义对象的几种方式 JavaScript中没有类的概念,只有对象. 在JavaScript中定义对象可以采用以下几种方式: 1.基于已有对象扩充其属性和方法 2.工 ...

  6. js对象的定义及处理

    一,概述 在Java语言中,我们可以定义自己的类,并根据这些类创建对象来使用,在Javascript中,我们也可以定义自己的类,例如定义User类.Hashtable类等等. 目前在Javascrip ...

  7. JavaScript学习12 JS中定义对象的几种方式【转】

    avaScript学习12 JS中定义对象的几种方式 转自:  http://www.cnblogs.com/mengdd/p/3697255.html JavaScript中没有类的概念,只有对象. ...

  8. JS中定义对象和集合

    在js中定义对象: 方式一: var obj = {}; obj['a']=1; obj['b']=2; 方式二: var obj=new Object(); obj.a=1; obj.b=2; 在j ...

  9. JS组件系列——表格组件神器:bootstrap table 包含了js对象的定义和对象成员函数的定义

    前言:之前一直在忙着各种什么效果,殊不知最基础的Bootstrap Table用法都没有涉及,罪过,罪过.今天补起来吧.上午博主由零开始自己从头到尾使用了一遍Bootstrap Table ,遇到不少 ...

随机推荐

  1. 用swift实现自动录音器

    基本介绍 自动录音与一般录音区别在:不用像微信那样按下录音-松手结束,而是根据说话声音的大小自动判断该录音和该停止的点,然后可以做到结束录音之后马上播放出来.类似于达到会说话的汤姆猫那样的效果. 在自 ...

  2. 自定义控件设置属性并实时展现并预览在xib中

    关键字: // @IBDesignable:实时看到xib设置后的效果 // @IBInspectable:给xib提供设置属性,可以xib中看到此属性 场景: 自定义一个UITextField,并提 ...

  3. minix2.0内核组织结构与公用头文件说明

    Minix2.0操作系统的源代码由两个目录组成:include/目录和src/目录 include/目录包含了操作系统所有的头文件(即.h文件) src/目录下包含了操作系统所有的源文件(.c或.s文 ...

  4. iOS 开发之路(使用WKWebView加载Html5) 四

    基于Swift 3 . Xcode 8 . iOS 10 下的WKWebView的使用. 首先是WKWebView的基本用法: var wk:WKWebView! var progBar:UIProg ...

  5. WPF学习之路(十)实例:用户注册

    通过一个注册用户的实例了解页面间数据的传递 首先构建一个User类  User.cs public class User { private string name; public string Na ...

  6. Visual Studio 开发平台的安装与单元测试

    一.安装VS2013 1.运行安装文件夹中的.exe文件,选择好安装路径与所需功能后开始安装 2.安装后第一次打开,需要一段时间 3.安装成功后,要打开VS2013,在工具栏中找到帮助选项卡,点击注册 ...

  7. JAVA中的枚举小结

    枚举 将一组有限集合创建为一种新的类型,集合里面的值可以作为程序组件使用: 枚举基本特性 以下代码是枚举的简单使用: 使用values方法返回enum实例的数组 使用ordinal方法返回每个enum ...

  8. web会话管理

    http协议是无状态的协议,也就是说服务器不知道这个http连接是那个浏览器发过来的. 要标识会话的唯一,有两种方法:1 Cookie  2 会话级cookie(开关浏览器算一次会话) 和 持久化的c ...

  9. 0010《SQL必知必会》笔记06-表的修改与删除

    1.表的修改: 1.1 删除列:ALTER TABLE 表名 DROP COLUMN 列名 1.2 添加列:ALTER TABLE 表名 ADD(列名 数据类型) 1.3 修改列名:ALTER TAB ...

  10. 《CLR via C#》读书笔记--基元类型、引用类型和值类型

    编程语言的基元类型 编译器直接支持的数据类型称为基元类型.基元类型直接映射到Framework类库中存在的类型.例如:C#中的int直接映射到System.Int32类型.下表给出了C#基元类型与对应 ...