将字符串中的字符 &
、<
、>
、"
(双引号), 以及 '
(单引号)转换为它们对应的 HTML 实体。
function convert(str) {
return str.replace(/&/g,'&').replace(/</g,'<').replace(/>/g,'>').replace(/"/g,'"').replace(/'/g,''');
}
一开始的方法简单粗暴,多少个实体就有多少个relpace()方法。但丝毫没有写代码的愉悦感。。。
而且既然是利用正则替换,将所有符号放在一起,使用relace()方法时再定义一个匿名函数,根据不同的符号替换为不同的HTML实体,自然想到将实体与符号对应,存储在一个对象里。
function convert(str) {
var entitys = {
'&' : '&',
'<' : '<',
'>' : '>',
'"' : '"',
"'" : '''
};
var regexp = new RegExp ('['+Object.keys(entitys).join('')+']','g');
return str.replace(regexp,function(matched){
return entitys[matched];
});
}