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. SQL Server全时区转换

    SQL Server全时区转换 假如你的应用程序是跨国(例如跨国银行交易)使用的话,那么数据库的一些国际化特性支持可以说是非常重要 其中最常见的就是各国时区上的差异,由于SQL Server getd ...

  2. Microsoft dotnetConf 2015 一些整理

    dotnetConf 2015 直播计划: 第一天 (10 个主讲) - .NET Product Teams 主讲人为 .NET 产品开发团队,.NET 产品主要包含 .NET Core.ASP.N ...

  3. 微软开源.NET Core的执行引擎CoreCLR{转载}

    继去年12月宣布.NET Core开源之后,微软拥抱开源的决心又向前迈了一步,Microsoft于昨日在 .NET Framework Blog上 宣布开源.NET Core 的执行引擎 CoreCL ...

  4. 分享基于Entity Framework的Repository模式设计(附源码)

    关于Repository模式,在这篇文章中有介绍,Entity Framework返回IEnumerable还是IQueryable? 这篇文章介绍的是使用Entity Framework实现的Rep ...

  5. ES7之Decorators实现AOP示例

    在上篇博文CoffeeScript实现Python装潢器中,笔者利用CoffeeScript支持的高阶函数,以及方法调用可省略括符的特性,实现了一个类似Python装潢器的日志Demo.这只是一种伪实 ...

  6. Redis分布式锁服务(八)

    阅读目录: 概述 分布式锁 多实例分布式锁 总结 概述 在多线程环境下,通常会使用锁来保证有且只有一个线程来操作共享资源.比如: object obj = new object(); lock (ob ...

  7. [转]GC简介

    [转]GC简介 原文链接:http://www.cnblogs.com/cposture/p/4845189.html 原文写得太好了,这里转一下. 1 GC机制 1.1 对象 从计算机的角度,装有数 ...

  8. 【敏捷开发】Android团队开发规范

    这里说的开发规范分成目录规范,项目和包名的命名规范,类,方法,变量和常量的命名规范这几种. 目录规范 目录规范——在开发中整体文件夹组织结构. Requirement——需求文档文件夹 Design— ...

  9. Echarts3 关系图-力导向布局图

    因为项目需要,要求实现类似力导图效果的图,我就瞄上了echarts. 注意事项1:由于我的项目要部署到内网,所以js文件要在本地,网上大多力导图都是echarts2的,而其又依赖zrender基础库, ...

  10. C#设计模式-原型模式

    在软件系统中,当创建一个类的实例的过程很昂贵或很复杂,并且我们需要创建多个这样类的实例时,如果我们用new操作符去创建这样的类实例,这未免会增加创建类的复杂度和耗费更多的内存空间,因为这样在内存中分配 ...