HTML的Encode(转码)和解码(Decode)在平时的开发中也是经常要处理的,在这里总结了使用javascript处理HTML的Encode(转码)和解码(Decode)的常用方式

一、用浏览器内部转换器实现转换

1.1.用浏览器内部转换器实现html转码

首先动态创建一个容器标签元素,如DIV,然后将要转换的字符串设置为这个元素的innerText(ie支持)或者textContent(火狐,google支持),最后返回这个元素的innerHTML,即得到经过HTML编码转换的字符串了。

1.2.用浏览器内部转换器实现html解码

首先动态创建一个容器标签元素,如DIV,然后将要转换的字符串设置为这个元素的innerHTML(ie,火狐,google都支持),最后返回这个元素的innerText(ie支持)或者textContent(火狐,google支持),即得到经过HTML解码的字符串了。

1.3.具体实现代码

复制代码

var HtmlUtil = {

   /*1.用浏览器内部转换器实现html转码*/

   htmlEncode:function (html){

       //1.首先动态创建一个容器标签元素,如DIV

       var temp = document.createElement ("div");

       //2.然后将要转换的字符串设置为这个元素的innerText(ie支持)或者textContent(火狐,google支持)

       (temp.textContent != undefined ) ? (temp.textContent = html) : (temp.innerText = html);

       //3.最后返回这个元素的innerHTML,即得到经过HTML编码转换的字符串了

       var output = temp.innerHTML;

      temp = null;

      return output;

  },

  /*2.用浏览器内部转换器实现html解码*/

  htmlDecode:function (text){

      //1.首先动态创建一个容器标签元素,如DIV

      var temp = document.createElement("div");

      //2.然后将要转换的字符串设置为这个元素的innerHTML(ie,火狐,google都支持)

      temp.innerHTML = text;

      //3.最后返回这个元素的innerText(ie支持)或者textContent(火狐,google支持),即得到经过HTML解码的字符串了。

      var output = temp.innerText || temp.textContent;

      temp = null;

      return output;

  }

};

1 var HtmlUtil = {

2     /*1.用浏览器内部转换器实现html转码*/

3     htmlEncode:function (html){

4         //1.首先动态创建一个容器标签元素,如DIV

5         var temp = document.createElement ("div");

6         //2.然后将要转换的字符串设置为这个元素的innerText(ie支持)或者textContent(火狐,google支持)

7         (temp.textContent != undefined ) ? (temp.textContent = html) : (temp.innerText = html);

8         //3.最后返回这个元素的innerHTML,即得到经过HTML编码转换的字符串了

9         var output = temp.innerHTML;

10         temp = null;

11         return output;

12     },

13     /*2.用浏览器内部转换器实现html解码*/

14     htmlDecode:function (text){

15         //1.首先动态创建一个容器标签元素,如DIV

16         var temp = document.createElement("div");

17         //2.然后将要转换的字符串设置为这个元素的innerHTML(ie,火狐,google都支持)

18         temp.innerHTML = text;

19         //3.最后返回这个元素的innerText(ie支持)或者textContent(火狐,google支持),即得到经过HTML解码的字符串了。

20         var output = temp.innerText || temp.textContent;

21         temp = null;

22         return output;

23     }

24 };

复制代码

测试:

1 var html = "<br>aaaaaa<p>bbbb</p>";

2 var encodeHtml = HtmlUtil.htmlEncode(html);

3 alert("encodeHtml:" + encodeHtml);

4 var decodeHtml = HtmlUtil.htmlDecode(encodeHtml);

5 alert("decodeHtml:" + decodeHtml);

运行结果:

二、用正则表达式进行转换处理

使用正则表达式也是一种常用的处理方式,实现原理就是使用替换的方式来实现转码和解码,转码时把<>,空格符,&,',""替换成html编码,解码就把html编码替换成对应的字符,实现代码如下:

复制代码

1 var HtmlUtil = {

2     /*1.用正则表达式实现html转码*/

3     htmlEncodeByRegExp:function (str){  

4          var s = "";

5          if(str.length == 0) return "";

6          s = str.replace(/&/g,"&amp;");

7          s = s.replace(/</g,"&lt;");

8          s = s.replace(/>/g,"&gt;");

9          s = s.replace(/ /g,"&nbsp;");

10          s = s.replace(/\'/g,"'");

11          s = s.replace(/\"/g,"&quot;");

12          return s;  

13    },

14    /*2.用正则表达式实现html解码*/

15    htmlDecodeByRegExp:function (str){  

16          var s = "";

17          if(str.length == 0) return "";

18          s = str.replace(/&amp;/g,"&");

19          s = s.replace(/&lt;/g,"<");

20          s = s.replace(/&gt;/g,">");

21          s = s.replace(/&nbsp;/g," ");

22          s = s.replace(/'/g,"\'");

23          s = s.replace(/&quot;/g,"\"");

24          return s;  

25    }

26 };

复制代码

测试代码:

1 var html = "<br>ccccc<p>aaaaa</p>";

2 var encodeHTML = HtmlUtil.htmlEncodeByRegExp(html);

3 alert("用正则表达式进行html转码,encodeHTML:" + encodeHTML);

4 var decodeHTML = HtmlUtil.htmlDecodeByRegExp("用正则表达式进行html解码:" + encodeHTML);

5 alert(decodeHTML);

测试结果:

三、封装HtmlUtil工具类

将两种方式封装HtmlUtil工具类,方便在开发中使用,完整代码如下:

复制代码

1 var HtmlUtil = {

2     /*1.用浏览器内部转换器实现html转码*/

3     htmlEncode:function (html){

4         //1.首先动态创建一个容器标签元素,如DIV

5         var temp = document.createElement ("div");

6         //2.然后将要转换的字符串设置为这个元素的innerText(ie支持)或者textContent(火狐,google支持)

7         (temp.textContent != undefined ) ? (temp.textContent = html) : (temp.innerText = html);

8         //3.最后返回这个元素的innerHTML,即得到经过HTML编码转换的字符串了

9         var output = temp.innerHTML;

10         temp = null;

11         return output;

12     },

13     /*2.用浏览器内部转换器实现html解码*/

14     htmlDecode:function (text){

15         //1.首先动态创建一个容器标签元素,如DIV

16         var temp = document.createElement("div");

17         //2.然后将要转换的字符串设置为这个元素的innerHTML(ie,火狐,google都支持)

18         temp.innerHTML = text;

19         //3.最后返回这个元素的innerText(ie支持)或者textContent(火狐,google支持),即得到经过HTML解码的字符串了。

20         var output = temp.innerText || temp.textContent;

21         temp = null;

22         return output;

23     },

24     /*3.用正则表达式实现html转码*/

25     htmlEncodeByRegExp:function (str){  

26          var s = "";

27          if(str.length == 0) return "";

28          s = str.replace(/&/g,"&amp;");

29          s = s.replace(/</g,"&lt;");

30          s = s.replace(/>/g,"&gt;");

31          s = s.replace(/ /g,"&nbsp;");

32          s = s.replace(/\'/g,"'");

33          s = s.replace(/\"/g,"&quot;");

34          return s;  

35    },

36    /*4.用正则表达式实现html解码*/

37    htmlDecodeByRegExp:function (str){  

38          var s = "";

39          if(str.length == 0) return "";

40          s = str.replace(/&amp;/g,"&");

41          s = s.replace(/&lt;/g,"<");

42          s = s.replace(/&gt;/g,">");

43          s = s.replace(/&nbsp;/g," ");

44          s = s.replace(/'/g,"\'");

45          s = s.replace(/&quot;/g,"\"");

46          return s;  

47    }

48 };

javascript处理HTML的Encode(转码)和Decode(解码)总结的更多相关文章

  1. javascript处理HTML的Encode(转码)和解码(Decode)

    HTML的Encode(转码)和解码(Decode)在平时的开发中也是经常要处理的,在这里总结了使用javascript处理HTML的Encode(转码)和解码(Decode)的常用方式 一.用浏览器 ...

  2. C#二维码生成与解码(二)

    本文内容在<C#二维码生成与解码>的基础上增加了纠错级别和Logo图标加入,增加了二维码的功能.关于透明度在这里没有单独显现,因为在颜色里面就已经包含,颜色值由8位8进制构成,最前面的两位 ...

  3. Java二维码生成与解码

      基于google zxing 的Java二维码生成与解码   一.添加Maven依赖(解码时需要上传二维码图片,所以需要依赖文件上传包) <!-- google二维码工具 --> &l ...

  4. C#实现二维码生成与解码

    前几天公司内部分享了一个关于二维码的例子,觉得挺好玩的,但没有提供完整的源码.有时候看到一个好玩的东西,总想自己Demo一个,于是抽空就自己研究了一下. 一.二维码的原理 工欲善其事,必先利其器.要生 ...

  5. windows8运行zxing源码 生成与解码二维码 详解(含注释与图解可直接运行)

    1 下载zxing2.1 2 本代码配置环境:eclipse.java1.6.windows8.zxing2.1 3 解压后将文件夹里面core/src下面的com文件夹导入到eclipse工程(工程 ...

  6. HTML-DEV-ToolLink(常用的在线字符串编解码、代码压缩、美化、JSON格式化、正则表达式、时间转换工具、二维码生成与解码等工具,支持在线搜索和Chrome插件。)

    HTML-DEV-ToolLink:https://github.com/easonjim/HTML-DEV-ToolLink 常用的在线字符串编解码.代码压缩.美化.JSON格式化.正则表达式.时间 ...

  7. 为什么请求时,需要使用URLEncode做encode转码操作(转)

    什么要对url进行encode 发现现在几乎所有的网站都对url中的汉字和特殊的字符,进行了urlencode操作,也就是: http://hi.baidu.com/%BE%B2%D0%C4%C0%C ...

  8. JavaScript的学习--生成二维码

    有一些耗cpu的计算,完全可以在客户端上计算,比如生成二维码. qrcode其实是通过计算,然后使用jquery实现图形渲染和画图.支持canvas和table两种方式生成我们所需的二维码. 具体用法 ...

  9. JavaScript之通用addLoadEvent代码源码

    在执行javascript代码时 很多情况下 我们是希望代码在网页加载完毕后立刻进行的 大家可能会立刻想到使用window.onload时间处理函数,然后通过 window.onload=functi ...

随机推荐

  1. VS2013.3 & VS2014 任务资源管理器

    Web 开发,特别是前端 Web 开发,正迅速变得像传统的后端开发一样复杂和精密.前端生成过程,可以囊括SASS 和LESS扩展.CSS/JS的压缩包.JSHint 或 JSLint的运行时 .或者更 ...

  2. 三种观察者模式的C#实现

    系列主题:基于消息的软件架构模型演变 说起观察者模式,估计在园子里能搜出一堆来.所以写这篇博客的目的有两点: 观察者模式是写松耦合代码的必备模式,重要性不言而喻,抛开代码层面,许多组件都采用了Publ ...

  3. 玩转JavaScript OOP[0]——基础类型

    前言 long long ago,大家普遍地认为JavaScript就是做一些网页特效的.处理一些事件的.我身边有一些老顽固的.NET程序员仍然停留在这种认知上,他们觉得没有后端开发肯定是构建不了系统 ...

  4. Objective-C中的Strong、Copy与MutableCopy

    面试过程中经常被问到ARC中Strong.Copy的区别是什么.普通的回答是:一样.文艺(正确)的回答是:分情况(我擦!WQY#$&Y**%OWEUR) 可以先参考这篇文章http://www ...

  5. 过段时间逐步使用HTML5新增的web worker等内容

    想来快2017年了,2013年前的手机应该很少有人用了,以后逐渐使用HTML5新增的高级API吧. 先把web worker的内容再熟悉一下,因为微软虚拟学院的'面向有经验开发人员的 JavaScri ...

  6. Thread.Sleep引发ThreadAbortException异常

    短信平台记录日志模块,是通过异步方式来记录的,即日志工具类里初始化一个Queue对象,公共的写日志方法的处理逻辑是把日志消息放到Queue里.构造器里设定一个死循环,不停的读队,然后把日志消息持久化到 ...

  7. php单条件查询,关键字查询

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  8. 手写原生ajax

    关于手写原生ajax重要不重要,各位道友自己揣摩吧, 本着学习才能进步,分享大家共同受益,自己也在自己博客里写一下 function createXMLHTTPRequest() { //1.创建XM ...

  9. 用SQL语句创建四个表并完成相关题目-10月18日更新

    1. 查询Student表中的所有记录的Sname.Ssex和Class列. 2. 查询教师所有的单位即不重复的Depart列. 3. 查询Student表的所有记录. 4. 查询Score表中成绩在 ...

  10. SSISDB4:Execution

    Execution是Package或Project的Execution Instance,每次执行都会生成一个唯一的ExecutionID,并记录Execution 执行的结果.在每次Executio ...