欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

javascript對(duì)HTML字符轉(zhuǎn)義與反轉(zhuǎn)義

 更新時(shí)間:2018年12月13日 11:44:34   作者:迪迪的博客  
這篇文章主要介紹了javascript對(duì)HTML字符轉(zhuǎn)義與反轉(zhuǎn)義,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧

1.背景:在項(xiàng)目中,經(jīng)常遇到一些字符需要進(jìn)行轉(zhuǎn)義后才能顯示到界面上,如“&”,在界面中顯示的是“&”,在html中書寫“&”,顯示在界面的中的依然是“&”。

這時(shí)候,就需要進(jìn)行轉(zhuǎn)義

 

2.解決方案

<script>

var HtmlUtil = {

 /*1.用瀏覽器內(nèi)部轉(zhuǎn)換器實(shí)現(xiàn)html轉(zhuǎn)碼*/

 htmlEncode:function (html){

 //1.首先動(dòng)態(tài)創(chuàng)建一個(gè)容器標(biāo)簽元素,如DIV

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

 //2.然后將要轉(zhuǎn)換的字符串設(shè)置為這個(gè)元素的innerText(ie支持)或者textContent(火狐,google支持)

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

 //3.最后返回這個(gè)元素的innerHTML,即得到經(jīng)過HTML編碼轉(zhuǎn)換的字符串了

 var output = temp.innerHTML;

 temp = null;

 return output;

 },

 /*2.用瀏覽器內(nèi)部轉(zhuǎn)換器實(shí)現(xiàn)html解碼*/

 htmlDecode:function (text){

 //1.首先動(dòng)態(tài)創(chuàng)建一個(gè)容器標(biāo)簽元素,如DIV

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

 //2.然后將要轉(zhuǎn)換的字符串設(shè)置為這個(gè)元素的innerHTML(ie,火狐,google都支持)

 temp.innerHTML = text;

 //3.最后返回這個(gè)元素的innerText(ie支持)或者textContent(火狐,google支持),即得到經(jīng)過HTML解碼的字符串了。

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

 temp = null;

 return output;

 },

 /*3.用正則表達(dá)式實(shí)現(xiàn)html轉(zhuǎn)碼*/

 htmlEncodeByRegExp:function (str){ 

 var s = "";

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

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

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

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

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

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

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

 return s; 

 },

 /*4.用正則表達(dá)式實(shí)現(xiàn)html解碼*/

 htmlDecodeByRegExp:function (str){ 

 var s = "";

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

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

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

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

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

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

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

 return s; 

 }

 };

</script> 

使用方法:HtmlUtil.htmlDecodeByRegExp("&amp;")

PS:使用正則

使用正則轉(zhuǎn)碼:

var value = document.getElementById('input').value.trim();
 //對(duì)用戶輸入進(jìn)行轉(zhuǎn)義
 value = value.replace(/&/g,"&amp;");
 value = value.replace(/</g,"&lt;");
 value = value.replace(/>/g,"&gt;");
 value = value.replace(/ /g,"&nbsp;");
 value = value.replace(/"/g,'&quot;');

使用正則解碼:

var value = e.target.innerText;
 // value = decodeURIComponent(value);
 value = value.replace(/&amp;/g,"&");
 value = value.replace(/&lt;/g,"<");
 value = value.replace(/&gt;/g,">");
 value = value.replace(/&nbsp;/g," ");
 value = value.replace(/&quot/g,"'");

下面是其他網(wǎng)友的補(bǔ)充

在編寫html時(shí),經(jīng)常需要轉(zhuǎn)義,才能正常顯示在頁面上。

并且,還可以防止xss。

解決方案:

一, 使用正則:

使用正則轉(zhuǎn)碼:

var value = document.getElementById('input').value.trim();
 //對(duì)用戶輸入進(jìn)行轉(zhuǎn)義
 value = value.replace(/&/g,"&amp;");
 value = value.replace(/</g,"&lt;");
 value = value.replace(/>/g,"&gt;");
 value = value.replace(/ /g,"&nbsp;");
 value = value.replace(/"/g,'&quot;');

使用正則解碼:

var value = e.target.innerText;
// value = decodeURIComponent(value);
 value = value.replace(/&amp;/g,"&");
 value = value.replace(/&lt;/g,"<");
 value = value.replace(/&gt;/g,">");
 value = value.replace(/&nbsp;/g," ");
 value = value.replace(/&quot/g,"'");

由于編輯器的編碼問題,其實(shí)就是

將<用&lt;替換,>替換為&gt;,空格替換為&nbsp;

以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • 更靠譜的H5橫豎屏檢測(cè)方法(js代碼)

    更靠譜的H5橫豎屏檢測(cè)方法(js代碼)

    這篇文章主要為大家詳細(xì)介紹了更靠譜的橫豎屏檢測(cè)方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2016-09-09
  • 詳談JS中實(shí)現(xiàn)種子隨機(jī)數(shù)及作用

    詳談JS中實(shí)現(xiàn)種子隨機(jī)數(shù)及作用

    這篇文章詳細(xì)介紹了種子隨機(jī)數(shù)在JS中如何實(shí)現(xiàn)以及有什么作用,希望能幫助有需要的人。下面一起來看看。
    2016-07-07
  • js中replace的用法總結(jié)

    js中replace的用法總結(jié)

    本篇文章主要是對(duì)js中replace的用法進(jìn)行了詳細(xì)的總結(jié)介紹,需要的朋友可以過來參考下,希望對(duì)大家有所幫助
    2013-12-12
  • 提升JS編程效率的19個(gè)實(shí)用技巧分享

    提升JS編程效率的19個(gè)實(shí)用技巧分享

    在實(shí)際工作中,開發(fā)者常面臨一些需巧妙編程解決的挑戰(zhàn),有時(shí)幾行代碼就能迎刃而解,本文整理了一系列實(shí)用代碼片段,助您輕松處理URL、DOM操作、事件處理等常見問題,希望對(duì)大家有所幫助
    2023-11-11
  • Javascript String 字符串操作包

    Javascript String 字符串操作包

    提供一個(gè) JS String 包,包含了一些常用的對(duì)字符串操作的函數(shù),詳細(xì)的請(qǐng)看源碼及演示
    2010-10-10
  • JS 文件本身編碼轉(zhuǎn)換 圖文教程

    JS 文件本身編碼轉(zhuǎn)換 圖文教程

    JS編碼轉(zhuǎn)換,這句話本身就是一句具有二重義的話。通常理解為JS文件里能轉(zhuǎn)換編碼的代碼,但是,我所碰到的問題并不是這樣的,是要解決JS文件本身的編碼問題,它是UTF-8編碼的還是ANSI編碼的?
    2009-10-10
  • 微信小程序?qū)崿F(xiàn)監(jiān)聽頁面滾動(dòng)

    微信小程序?qū)崿F(xiàn)監(jiān)聽頁面滾動(dòng)

    這篇文章主要為大家詳細(xì)介紹了微信小程序?qū)崿F(xiàn)監(jiān)聽頁面滾動(dòng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-06-06
  • JS實(shí)現(xiàn)倒計(jì)時(shí)圖文效果

    JS實(shí)現(xiàn)倒計(jì)時(shí)圖文效果

    這篇文章主要為大家詳細(xì)介紹了JS實(shí)現(xiàn)倒計(jì)時(shí)圖文效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-11-11
  • 淺談JavaScript 函數(shù)參數(shù)傳遞到底是值傳遞還是引用傳遞

    淺談JavaScript 函數(shù)參數(shù)傳遞到底是值傳遞還是引用傳遞

    下面小編就為大家?guī)硪黄獪\談JavaScript 函數(shù)參數(shù)傳遞到底是值傳遞還是引用傳遞。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2016-08-08
  • JS獲取Promise對(duì)象里面的值問題

    JS獲取Promise對(duì)象里面的值問題

    這篇文章主要介紹了JS如何獲取Promise對(duì)象里面的值問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-01-01

最新評(píng)論