Maison > Questions et réponses > le corps du texte
Je souhaite remplacer les chaînes incluses entre doubles accolades par des valeurs réelles, mais je ne peux en remplacer qu'une. Je ne sais pas pourquoi ?
var tpl = '/cube_xinbao_dial_result/{{report_type}}/{{query}}';
var data = {report_type:1, query: '2323'}
function render(tpl, data){
var re = /{{([^}]+)?}}/g;
var match = '';
while(match = re.exec(tpl)){
tpl = tpl.replace(match[0],data[match[1]]);
}
return tpl;
}
console.log(render(tpl,data));
漂亮男人2017-06-05 11:15:51
String.replace prend également en charge les expressions régulières comme paramètres, réécrites pour vous
var tpl = '/cube_xinbao_dial_result/{{report_type}}/{{query}}';
var data = {report_type:1, query: '2323'}
function render(tpl, data){
var re = /{{([^}]+)?}}/g;
return tpl.replace(re, function(
var tpl = '/cube_xinbao_dial_result/{{report_type}}/{{query}}';
var data = {report_type:1, query: '2323'}
function render(tpl, data){
var re = /{{([^}]+)?}}/; //不要全局匹配就可以
var match = '';
while(match = re.exec(tpl)){
tpl = tpl.replace(match[0],data[match[1]]);
}
return tpl;
}
console.log(render(tpl,data));
/*
/cube_xinbao_dial_result/1/2323
*/
, , ){
if( in data ){
return data[];
}else{
return "[DATA."+ .toUpperCase() + "]"; //如果没有,提示标签错误
}
});
}
console.log(render(tpl,data));
/*
/cube_xinbao_dial_result/1/2323
*/
console.log(render(tpl,{query:1234}));
/*
/cube_xinbao_dial_result/[DATA.REPORT_TYPE]/1234
*/
Si vous insistez pour utiliser votre méthode d'origine, vous devez annuler le paramètre global g
rrreee某草草2017-06-05 11:15:51
L'objet
RegExp a un attribut, lastIndex, qui représente que la position de 一个整数,标示开始下一次匹配的字符位置。
。当exec第一次执行成功后,lastIndex为匹配项位置+1。正因为这样,再次调用才会会获得下一个匹配项。
回到你这个例子,第一次循环后,re的lastIndex为40,而此时tpl变为了tpl="/cube_xinbao_dial_result/1/{{query}}"
显然你要匹配的query
est antérieure à 40, donc il échoue lors d'une nouvelle correspondance, exec renvoie null et la boucle saute.
淡淡烟草味2017-06-05 11:15:51
var tpl = '/cube_xinbao_dial_result/{{report_type}}/{{query}}';
var data = {report_type:1, query: '223'}
function render(tpl, data){
var re = /{{([^}]+)?}}/g;
var tpl2=tpl;
tpl.match(re).forEach(function (val) {
tpl2= tpl2.replace(val,data[val.substring(2,val.length-2)]);
});
return tpl2;
}
console.log(render(tpl,data));
Résultat de sortie
/cube_xinbao_dial_result/1/223