我希望在字符串中进行搜索和替换。它搜索以“$”开头的任何单词,并用数组中的值替换它。例如,如果字符串是:
[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响应)是我希望变量更改为的数组。
有人可以帮帮我吗?提前致谢
答案 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)
});