js实体转化

将字符串中的字符 &<>" (双引号), 以及 ' (单引号)转换为它们对应的 HTML 实体。

function convert(str) {
  return str.replace(/&/g,'&amp;').replace(/</g,'&lt;').replace(/>/g,'&gt;').replace(/"/g,'&quot;').replace(/'/g,'&apos;');  
}

一开始的方法简单粗暴,多少个实体就有多少个relpace()方法。但丝毫没有写代码的愉悦感。。。

而且既然是利用正则替换,将所有符号放在一起,使用relace()方法时再定义一个匿名函数,根据不同的符号替换为不同的HTML实体,自然想到将实体与符号对应,存储在一个对象里。

function convert(str) {
   var entitys = {
    '&' : '&amp;',
    '<' : '&lt;',
    '>' : '&gt;',
    '"' : '&quot;',
    "'" : '&apos;'
  };
  var regexp = new RegExp ('['+Object.keys(entitys).join('')+']','g');
  return str.replace(regexp,function(matched){
    return entitys[matched];
  });  
}



阅读更多
文章标签: Js 实体转化
个人分类: 前端系列学习
想对作者说点什么? 我来说一句

没有更多推荐了,返回首页

关闭
关闭
关闭