码迷,mamicode.com
首页 > 其他好文 > 详细

寄生构造函数模式创建对象

时间:2019-05-05 23:42:05      阅读:143      评论:0      收藏:0      [点我收藏+]

标签:imp   假设   不能   important   put   ali   模式   添加   overflow   

这个模式可以在特殊的情况下用来为对象创建构造函数

例子一

假设我们想创建一个具有额外方法的特殊数组。

由于不能直接修改Array构造函数(此为使用寄生构造函数模式的原因)

function SpecialArray() {

    // 创建数组
    var values = new Array();

    // 添加值
    // values.push.apply(values, arguments);
    values.push(...arguments);

    // 添加方法
    values.toPipedString = function() {
        return this.join("|");
    };

    // 返回数组
    return values;
}

var colors = new SpecialArray("red""blue""green");
console.log(colors.toPipedString()); // console: "red|blue|green"
例子二

原始库对象的方法不好用, 我们想创建具有更简便方法的对象

function SpecialRapheal(id{

    // 创建Raphael实例
    var r = Raphael(id);

    // 添加方法
    r.line = function(obj{
        return this.path(obj.path)
            .attr({"stroke": obj.strokeColor, "stroke-width": obj.strokeWidth})
            .translate(obj.x || 0, obj.y || 0);
    };

    r.rec = function(obj{
        return this.path(obj.path)
            .attr({"stroke": obj.strokeColor, "fill": obj.fillColor})
            .translate(obj.x || 0, obj.y || 0);
    };

    r.cir = function(obj{
        return this.circle(obj.cx, obj.cy, obj.r)
            .attr({"stroke": obj.strokeColor, "stroke-width": obj.strokeWidth, "fill": obj.fillColor})
            .translate(obj.x || 0, obj.y || 0);
    }

    return r;
}

寄生构造函数模式创建对象

标签:imp   假设   不能   important   put   ali   模式   添加   overflow   

原文地址:https://www.cnblogs.com/rencoo/p/10816838.html

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