JS实现HTML标签转义及反转义
简单说一下业务场景,前台用户通过input输入内容,在离开焦点时,将内容在div中显示。
这时遇到一个问题,如果用户输入了html标签,则在div显示中,标签被解析。
由于是纯前端操作,不涉及后端,因此需要通过js对输入内容进行转义。
这里提供一个非常简单有效的转义方案,利用了innerHTML和innerText
注:火狐不支持innerText,需要使用textContent属性,而IE早期版本不支持此属性,为了同时兼容IE及火狐,需要进行判断操作.
因为innerText(textContent)会获取纯文本内容,忽略html节点标签,而innerHTML会显示标签内容,
所以我们先将需转义的内容赋值给innerText(textContent),再获取它的innerHTML属性,这时获取到的就是转义后文本内容。
代码如下:
functionHTMLEncode(html){
vartemp=document.createElement("div");
(temp.textContent!=null)?(temp.textContent=html):(temp.innerText=html);
varoutput=temp.innerHTML;
temp=null;
returnoutput;
}
vartagText="<p><b>123&456</b></p>";
console.log(HTMLEncode(tagText));//<p><b>123&456</b></p>
通过测试结果,可以看到html标签及&符都被转义后保存。
同理,反转义的方法为先将转义文本赋值给innerHTML,然后通过innerText(textContent)获取转义前的文本内容
functionHTMLDecode(text){
vartemp=document.createElement("div");
temp.innerHTML=text;
varoutput=temp.innerText||temp.textContent;
temp=null;
returnoutput;
}
vartagText="<p><b>123&456</b></p>";
varencodeText=HTMLEncode(tagText);
console.log(encodeText);//<p><b>123&456</b></p>
console.log(HTMLDecode(encodeText));//<p><b>123&456</b></p>
编码反编码核心函数
functionhtml_encode(str)
{
vars="";
if(str.length==0)return"";
s=str.replace(/&/g,"&");
s=s.replace(/</g,"<");
s=s.replace(/>/g,">");
s=s.replace(//g," ");
s=s.replace(/\'/g,"'");
s=s.replace(/\"/g,""");
s=s.replace(/\n/g,"<br/>");
returns;
}
functionhtml_decode(str)
{
vars="";
if(str.length==0)return"";
s=str.replace(/&/g,"&");
s=s.replace(/</g,"<");
s=s.replace(/>/g,">");
s=s.replace(/ /g,"");
s=s.replace(/'/g,"\'");
s=s.replace(/"/g,"\"");
s=s.replace(/<br\/>/g,"\n");
returns;
}
console.log(html_decode('<div>123</div>'));
console.log(html_encode(html_decode('<div>123</div>')));
实例
<!DOCTYPEhtml>
<html>
<head>
<metacharset="utf-8">
<title>test</title>
<scriptsrc="https://cdn.staticfile.org/jquery/1.10.2/jquery.min.js"></script>
<scripttype="text/javascript">
functionhtml_encode(str)
{
vars="";
if(str.length==0)return"";
s=str.replace(/&/g,"&");
s=s.replace(/</g,"<");
s=s.replace(/>/g,">");
s=s.replace(//g," ");
s=s.replace(/\'/g,"'");
s=s.replace(/\"/g,""");
s=s.replace(/\n/g,"<br/>");
returns;
}
functionhtml_decode(str)
{
vars="";
if(str.length==0)return"";
s=str.replace(/&/g,"&");
s=s.replace(/</g,"<");
s=s.replace(/>/g,">");
s=s.replace(/ /g,"");
s=s.replace(/'/g,"\'");
s=s.replace(/"/g,"\"");
s=s.replace(/<br\/>/g,"\n");
returns;
}
console.log(html_decode('<div>123</div>'));
console.log(html_encode(html_decode('<div>123</div>')));
</script>
</head>
<body>
</body>
</html>
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持毛票票!