我希望在字符串中进行搜索和替换。它搜索任何以"$“开头的单词,并将其替换为数组中的值。例如,如果字符串为:
[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();
}
});
格式是它将替换的字符串,data (来自JSON响应)是我想要将变量更改为的数组。
有没有人能帮我一下?提前感谢
发布于 2012-04-02 12:35:33
然后添加为最后一次替换
tmp = tmp.replace(/\$([a-z]+)/gi, function(match, v) {
return data[v] || v;
})
注意,在data[v]
未定义的情况下,您可以返回其他内容,如data[v] || ["not found", v].join(' ')
,以跟踪缺少的变量
发布于 2012-04-02 12:40:04
我不是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));
});
发布于 2012-04-02 12:41:24
你可以这样做
tmp = tmp.replace(/\$([a-z]+)/gi, function(match) {
match = match.replace('$', '');
return (data[match] || match)
});
https://stackoverflow.com/questions/9976395
复制相似问题