码迷,mamicode.com
首页 > 编程语言 > 详细

JavaScript封装的几种方式

时间:2016-12-15 09:35:20      阅读:254      评论:0      收藏:0      [点我收藏+]

标签:对象   ber   name   js对象   csharp   on()   类型   指定   表达式   

JS 对象封装的常用方式

JS是一门面向对象语言,其对象是用prototype属性来模拟的。来看看如何封装JS对象.

常规封装

function Person (name,age,sex){
    this.name = name;
    this.age = age;
    this.sex = sex;
}

Pserson.prototype = {
    constructor:Person,
    sayHello:function(){
        console.log(‘hello‘);
    }
}

 这种方式是比较常见的方式,比较直观,但是Person() 的职责是构造对象,如果把初始化的事情也放在里面完成,代码就会显得繁琐,如果放在一个方法里初始化会不会好点呢?

 

升级版 (常见)

function Person (info){
    this._init_(info);
}

Pserson.prototype = {
    constructor : Person,
    _init_ : function(info) {
        this.name = info.name;
        this.age = info.age;
        this.sex = info.sex;
    }
    sayHello:function(){
        console.log(‘hello‘);
    }
}

 可是,说到这里就发现,name,age,sex 并没有在Person里面申明,哪来的呢???

 

new 的执行原理

new 的执行过程可以用下面一个函数来代替

 var myNew = function(constructor, args) {
        var o = {};
        o.__proto__ = constructor.prototype;
        var res = constructor.apply(o, args);
        var type = typeof res;
        if ([‘string‘, ‘number‘, ‘boolean‘, ‘null‘, ‘undefined‘].indexOf(type) !== -1) {
            return o;
        }
        return res;
    }

 

解释:
首先通过 var o = {} 构造一个空对象.
然后将 构造函数的原型属性prototype赋值给o 的原型对象__proto__ 。这样,在执行 this.init(info); 这句话的时候,对象 o 就可以在其原型对象中查找_init_ 方法。(原型链)。
之后这句话 就是精髓了。

var res = constructor.apply(o,args);

 以o为上下文调用函数,同时将参数作为数组传递。那么,

 this._init_(info);

 这句话就会被 o 执行,函数

 _init_ : function(info) {
        this.name = info.name;
        this.age = info.age;
        this.sex = info.sex;
    }

 

以 o 为上下文调用,o也将拥有自己的 name,age,sex 属性。

如果在构造函数中,return 复合类型,包括对象,函数,和正则表达式,那么就会直接返回这个对象,否则,返回 o

 

call方法:
语法:call([thisObj[,arg1[, arg2[,   [,.argN]]]]])
定义:调用一个对象的一个方法,以另一个对象替换当前对象。
说明:
call 方法可以用来代替另一个对象调用一个方法。call 方法可将一个函数的对象上下文从初始的上下文改变为由 thisObj 指定的新对象。
如果没有提供 thisObj 参数,那么 Global 对象被用作 thisObj。

apply方法:
语法:apply([thisObj[,argArray]])
定义:应用某一对象的一个方法,用另一个对象替换当前对象。
说明:
如果 argArray 不是一个有效的数组或者不是 arguments 对象,那么将导致一个 TypeError。
如果没有提供 argArray 和 thisObj 任何一个参数,那么 Global 对象将被用作 thisObj, 并且无法被传递任何参数。

 

JavaScript封装的几种方式

标签:对象   ber   name   js对象   csharp   on()   类型   指定   表达式   

原文地址:http://www.cnblogs.com/sunliyuan/p/6181895.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!