2

我正在开发一个简单的浏览器泥客户端,我需要为字符串处理提供一些基本功能。所以,当一些用户施放一个集体法术时,它应该被折叠成一个字符串,即CAST: User1 -> [target1, target2]。我写了代码:

function CastGroup(caster, cast, targets, text) {
    this.cast = cast || '';
    this.targets = targets || [];
    this.caster = caster || '';
    this.text = text || '';
}

CastGroup.prototype = new String;

CastGroup.prototype.render = function(){
    var targets = this.targets ? '[' + this.targets.join(', ') + ']' : '';
    var text = '<b>CAST</b>: ' + this.caster + ' ' + this.cast + ' -> ' + targets + '\n';
    this.text = text;

    return new CastGroup(this.caster, this.cast, this.targets, this.text);
};

CastGroup.prototype.valueOf = function(){
    return this.text;
};

CastGroup.prototype.toString = function(){
    return this.render();
};


var c = new CastGroup('name', 'supercast', ['1', '2']);
console.log(typeof c); // object
var s = c.replace('name', 'nomnom');
console.log(typeof s); // string

任何字符串函数,即String.replace()替换原始对象。我怎样才能避免它?

编辑1

我有一个后处理突出显示“引擎”,它调用用户的回调。用户应该认为,该捆绑包只有字符串。bundle是一个包含原始文本、纯文本和彩色文本的数组。用户在用户空间中定义回调,它应该完成所有突出显示的工作。

function process_highlights(bundle){
    if (!bundle || !bundle.length){
        return bundle;
    }

    var highlight_result = bundle;
    for (var i=0; i<HIGHLIGHTS.length; i++){
        highlight_result = HIGHLIGHTS[i](highlight_result);
    }
    return highlight_result;
}

因此,文本处理链看起来像:original_bundle-> subst_processor-> trigger_processor-> highlight_processor-> output_window。所有这些处理器都接受并返回一个应该包含字符串的包。我现在无法更改设计。

4

2 回答 2

0

如果我正确理解你的问题,你需要删除这个:CastGroup.prototype = new String;

并这样做:CastGroup.prototype = String.prototype;

这将为您提供String方法而不返回新String对象。要了解有关此内容的更多信息(以及一般的高级 Javascript),请查看这些幻灯片

更新:

我想我现在更好地理解了你的问题。string 方法返回一个新字符串,这replace就是它覆盖您的对象的原因。

您根本不需要从String对象继承。String方法甚至不适用于对象(因此 delete CastGroup.prototype = new String)。您要做的只是直接修改对象的值。

如果您需要修改 'text' 的值CastGroup,则声明另一个方法:

CastGroup.prototype.modifyText = function (findValue, replaceValue) {
    var text = this.text;
    this.text = text.replace(findValue, replaceValue);
    return this;
};
于 2013-06-03T16:43:10.960 回答
0

这对我有用。

CastGroup.prototype.replace = function() {
    this.text = this.text.replace.apply(this.text, arguments);
    return this;
};

覆盖对象中的原型,更新需要更新的字段,然后返回对象。

于 2013-06-03T18:30:59.000 回答