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>
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持毛票票!