Javascript将部分字符串替换为变量

时间:2012-04-02 12:25:50

标签: javascript jquery string replace

我希望在字符串中进行搜索和替换。它搜索以“$”开头的任何单词,并用数组中的值替换它。例如,如果字符串是:

[div class='news'][h4]$title[/h4][p]$desc[/p][/div]

它将[]替换为<> (已经完成了)。但后来我希望它用数组中的数据替换$ title。因此数据[“title”]和$ desc将被数据[“desc”]替换。 我到目前为止的代码是

var obj = $('#'+id);
var url = $(obj).attr('loadJSON');
var format = $(obj).attr('responseFormat');
$.getJSON(url, function(data) {
    var html = "";
    for(var i=0;i<data.length;i++) {
        var tmp = format;
        tmp = tmp.replace(/\[+(.*?)\]+/g,"<$1>");
        tmp = tmp.replace();
    }
});

格式是它将替换的字符串,而数据(来自JSON响应)是我希望变量更改为的数组。

有人可以帮帮我吗?提前致谢

3 个答案:

答案 0 :(得分:4)

然后添加为最后替换

tmp = tmp.replace(/\$([a-z]+)/gi, function(match, v) {
   return data[v] || v;
})

请注意,如果data[v]未定义,您可以返回其他内容,例如data[v] || ["not found", v].join(' '),以便跟踪缺少的变量

答案 1 :(得分:0)

我不是JS专家,但这在很多方面看起来都不对...你的数据对象应该是一个JS对象,就像{ title: 'Generic title.', description: 'It's a generic title' }一样。

为什么不将值放入段落元素中,然后将它们插入到div中(即,将它们附加到它们中)。像这样:

$.getJSON(url, function(data) {
    $('div.news').append($('<p />').text(data.title));
    $('div.news').append($('<p />').txt(data.description));
});

答案 2 :(得分:0)

你可以做到

tmp = tmp.replace(/\$([a-z]+)/gi, function(match) {
    match = match.replace('$', '');
   return (data[match] || match)
});

http://jsfiddle.net/uZbk8/