【问题标题】:Is there an easy way to convert text into HTML in JavaScript? [duplicate]有没有一种简单的方法可以在 JavaScript 中将文本转换为 HTML? [复制]
【发布时间】:2012-04-30 07:15:13
【问题描述】:

可能重复:
Escaping HTML strings with jQuery
JavaScript/jQuery HTML Encoding

例如,如果我想在 HTML 中向用户显示字符串 x < 3,我需要将 < 字符替换为 <。在 JavaScript 或 jQuery 中是否有预建函数可以将任何文本字符串转换为相应的 HTML?

【问题讨论】:

标签: javascript jquery html


【解决方案1】:

如果要使用jQuery,可以使用text(string)方法。

$(".selector").text("x < 5");

http://api.jquery.com/text/

【讨论】:

    【解决方案2】:

    或者,简单点,做这个

    var str1 = "x < 3";
    str1.replace(/</g, '&lt;');
    

    这是来自另一个问题的function

    function htmlEscape(str) {
        return String(str)
                .replace(/&/g, '&amp;')
                .replace(/"/g, '&quot;')
                .replace(/'/g, '&#39;')
                .replace(/</g, '&lt;')
                .replace(/>/g, '&gt;');
    }
    

    或者,使用jQuery的优秀作弊Source

    function htmlEncode(value){
      return $('<div/>').text(value).html();
    }
    
    function htmlDecode(value){
      return $('<div/>').html(value).text();
    }
    

    【讨论】:

    • 但这并不适用于所有危险的文本字符。它只处理'
    • @Dejas,我已经更新了我的答案。请查看
    【解决方案3】:

    使用 jQuery,也许您不必对文本进行 html 编码:

    $("div.test").text("<b></b> for bold!");
    

    将 div 的内部 html 设置为:

    &lt;b&gt;&lt;/b&gt; for bold!
    

    然后您可以使用以下方法检索此 html:

    $("div.test").html();
    

    【讨论】:

      【解决方案4】:

      你可以使用 jQuery 的力量:

      var str = "x < 3";
      str = $('<div>').text(str).html();
      

      会给你"x &amp;lt; 3" 结果。字符串"Alpha &amp; Omega" 会变成"Alpha &amp;amp; Omega" 等等。

      【讨论】:

        【解决方案5】:

        假设您已将字符串存储到变量中

        k = " <!"#$\'";
        

        那么当你需要“打印”这些值时使用

        escape (k );
        

        【讨论】:

        • 而字符串'x &lt; 3'会变成x%20%3C%203
        • escape() 适用于网络传输,不适用于显示。
        【解决方案6】:

        有一个php函数名htmlentities,我为JS找到了这个:

        function HTMLentities(texte) {
        
        texte = texte.replace(/"/g,'&quot;'); // 34 22
        texte = texte.replace(/&/g,'&amp;'); // 38 26
        texte = texte.replace(/\'/g,'&#39;'); // 39 27
        texte = texte.replace(/</g,'&lt;'); // 60 3C
        texte = texte.replace(/>/g,'&gt;'); // 62 3E
        texte = texte.replace(/\^/g,'&circ;'); // 94 5E
        texte = texte.replace(/‘/g,'&lsquo;'); // 145 91
        texte = texte.replace(/’/g,'&rsquo;'); // 146 92
        texte = texte.replace(/“/g,'&ldquo;'); // 147 93
        texte = texte.replace(/”/g,'&rdquo;'); // 148 94
        texte = texte.replace(/•/g,'&bull;'); // 149 95
        texte = texte.replace(/–/g,'&ndash;'); // 150 96
        texte = texte.replace(/—/g,'&mdash;'); // 151 97
        texte = texte.replace(/˜/g,'&tilde;'); // 152 98
        texte = texte.replace(/™/g,'&trade;'); // 153 99
        texte = texte.replace(/š/g,'&scaron;'); // 154 9A
        texte = texte.replace(/›/g,'&rsaquo;'); // 155 9B
        texte = texte.replace(/œ/g,'&oelig;'); // 156 9C
        texte = texte.replace(//g,'&#357;'); // 157 9D
        texte = texte.replace(/ž/g,'&#382;'); // 158 9E
        texte = texte.replace(/Ÿ/g,'&Yuml;'); // 159 9F
        // texte = texte.replace(/ /g,'&nbsp;'); // 160 A0
        texte = texte.replace(/¡/g,'&iexcl;'); // 161 A1
        texte = texte.replace(/¢/g,'&cent;'); // 162 A2
        texte = texte.replace(/£/g,'&pound;'); // 163 A3
        //texte = texte.replace(/ /g,'&curren;'); // 164 A4
        texte = texte.replace(/¥/g,'&yen;'); // 165 A5
        texte = texte.replace(/¦/g,'&brvbar;'); // 166 A6
        texte = texte.replace(/§/g,'&sect;'); // 167 A7
        texte = texte.replace(/¨/g,'&uml;'); // 168 A8
        texte = texte.replace(/©/g,'&copy;'); // 169 A9
        texte = texte.replace(/ª/g,'&ordf;'); // 170 AA
        texte = texte.replace(/«/g,'&laquo;'); // 171 AB
        texte = texte.replace(/¬/g,'&not;'); // 172 AC
        texte = texte.replace(/­/g,'&shy;'); // 173 AD
        texte = texte.replace(/®/g,'&reg;'); // 174 AE
        texte = texte.replace(/¯/g,'&macr;'); // 175 AF
        texte = texte.replace(/°/g,'&deg;'); // 176 B0
        texte = texte.replace(/±/g,'&plusmn;'); // 177 B1
        texte = texte.replace(/²/g,'&sup2;'); // 178 B2
        texte = texte.replace(/³/g,'&sup3;'); // 179 B3
        texte = texte.replace(/´/g,'&acute;'); // 180 B4
        texte = texte.replace(/µ/g,'&micro;'); // 181 B5
        texte = texte.replace(/¶/g,'&para'); // 182 B6
        texte = texte.replace(/·/g,'&middot;'); // 183 B7
        texte = texte.replace(/¸/g,'&cedil;'); // 184 B8
        texte = texte.replace(/¹/g,'&sup1;'); // 185 B9
        texte = texte.replace(/º/g,'&ordm;'); // 186 BA
        texte = texte.replace(/»/g,'&raquo;'); // 187 BB
        texte = texte.replace(/¼/g,'&frac14;'); // 188 BC
        texte = texte.replace(/½/g,'&frac12;'); // 189 BD
        texte = texte.replace(/¾/g,'&frac34;'); // 190 BE
        texte = texte.replace(/¿/g,'&iquest;'); // 191 BF
        texte = texte.replace(/À/g,'&Agrave;'); // 192 C0
        texte = texte.replace(/Á/g,'&Aacute;'); // 193 C1
        texte = texte.replace(/Â/g,'&Acirc;'); // 194 C2
        texte = texte.replace(/Ã/g,'&Atilde;'); // 195 C3
        texte = texte.replace(/Ä/g,'&Auml;'); // 196 C4
        texte = texte.replace(/Å/g,'&Aring;'); // 197 C5
        texte = texte.replace(/Æ/g,'&AElig;'); // 198 C6
        texte = texte.replace(/Ç/g,'&Ccedil;'); // 199 C7
        texte = texte.replace(/È/g,'&Egrave;'); // 200 C8
        texte = texte.replace(/É/g,'&Eacute;'); // 201 C9
        texte = texte.replace(/Ê/g,'&Ecirc;'); // 202 CA
        texte = texte.replace(/Ë/g,'&Euml;'); // 203 CB
        texte = texte.replace(/Ì/g,'&Igrave;'); // 204 CC
        texte = texte.replace(/Í/g,'&Iacute;'); // 205 CD
        texte = texte.replace(/Î/g,'&Icirc;'); // 206 CE
        texte = texte.replace(/Ï/g,'&Iuml;'); // 207 CF
        texte = texte.replace(/Ð/g,'&ETH;'); // 208 D0
        texte = texte.replace(/Ñ/g,'&Ntilde;'); // 209 D1
        texte = texte.replace(/Ò/g,'&Ograve;'); // 210 D2
        texte = texte.replace(/Ó/g,'&Oacute;'); // 211 D3
        texte = texte.replace(/Ô/g,'&Ocirc;'); // 212 D4
        texte = texte.replace(/Õ/g,'&Otilde;'); // 213 D5
        texte = texte.replace(/Ö/g,'&Ouml;'); // 214 D6
        texte = texte.replace(/×/g,'&times;'); // 215 D7
        texte = texte.replace(/Ø/g,'&Oslash;'); // 216 D8
        texte = texte.replace(/Ù/g,'&Ugrave;'); // 217 D9
        texte = texte.replace(/Ú/g,'&Uacute;'); // 218 DA
        texte = texte.replace(/Û/g,'&Ucirc;'); // 219 DB
        texte = texte.replace(/Ü/g,'&Uuml;'); // 220 DC
        texte = texte.replace(/Ý/g,'&Yacute;'); // 221 DD
        texte = texte.replace(/Þ/g,'&THORN;'); // 222 DE
        texte = texte.replace(/ß/g,'&szlig;'); // 223 DF
        texte = texte.replace(/à/g,'&aacute;'); // 224 E0
        texte = texte.replace(/á/g,'&aacute;'); // 225 E1
        texte = texte.replace(/â/g,'&acirc;'); // 226 E2
        texte = texte.replace(/ã/g,'&atilde;'); // 227 E3
        texte = texte.replace(/ä/g,'&auml;'); // 228 E4
        texte = texte.replace(/å/g,'&aring;'); // 229 E5
        texte = texte.replace(/æ/g,'&aelig;'); // 230 E6
        texte = texte.replace(/ç/g,'&ccedil;'); // 231 E7
        texte = texte.replace(/è/g,'&egrave;'); // 232 E8
        texte = texte.replace(/é/g,'&eacute;'); // 233 E9
        texte = texte.replace(/ê/g,'&ecirc;'); // 234 EA
        texte = texte.replace(/ë/g,'&euml;'); // 235 EB
        texte = texte.replace(/ì/g,'&igrave;'); // 236 EC
        texte = texte.replace(/í/g,'&iacute;'); // 237 ED
        texte = texte.replace(/î/g,'&icirc;'); // 238 EE
        texte = texte.replace(/ï/g,'&iuml;'); // 239 EF
        texte = texte.replace(/ð/g,'&eth;'); // 240 F0
        texte = texte.replace(/ñ/g,'&ntilde;'); // 241 F1
        texte = texte.replace(/ò/g,'&ograve;'); // 242 F2
        texte = texte.replace(/ó/g,'&oacute;'); // 243 F3
        texte = texte.replace(/ô/g,'&ocirc;'); // 244 F4
        texte = texte.replace(/õ/g,'&otilde;'); // 245 F5
        texte = texte.replace(/ö/g,'&ouml;'); // 246 F6
        texte = texte.replace(/÷/g,'&divide;'); // 247 F7
        texte = texte.replace(/ø/g,'&oslash;'); // 248 F8
        texte = texte.replace(/ù/g,'&ugrave;'); // 249 F9
        texte = texte.replace(/ú/g,'&uacute;'); // 250 FA
        texte = texte.replace(/û/g,'&ucirc;'); // 251 FB
        texte = texte.replace(/ü/g,'&uuml;'); // 252 FC
        texte = texte.replace(/ý/g,'&yacute;'); // 253 FD
        texte = texte.replace(/þ/g,'&thorn;'); // 254 FE
        texte = texte.replace(/ÿ/g,'&yuml;'); // 255 FF
        return texte;
        }
        

        【讨论】:

        • 这看起来可行,但我认为它可能太耗时了。
        • 我同意,这是一个完整的包来回答这个问题。
        【解决方案7】:

        这会替换 javascript 中的字符:

        function replaceStr(str) {
          return str
              .replace(/&/g, "&amp;")
              .replace(/</g, "&lt;")
              .replace(/>/g, "&gt;")
              .replace(/"/g, "&quot;")
              .replace(/'/g, "&#039;");
        }
        

        【讨论】:

          【解决方案8】:

          您可以使用 php.js 库的一部分,它实现了从 php 到 js 的已知功能。还有大名鼎鼎的htmlspecialcharshttp://phpjs.org/functions/htmlspecialchars:426 显然,从函数中删除不必要的部分:)

          也可以看看:HtmlSpecialChars equivalent in Javascript?

          【讨论】:

            【解决方案9】:

            如果您使用的是 jQuery,您可以按照这个答案的建议进行操作:

            HTML-encoding lost when attribute read from input field

            【讨论】:

              猜你喜欢
              • 2021-12-25
              • 1970-01-01
              • 2022-09-24
              • 2011-01-19
              • 2010-09-06
              • 1970-01-01
              • 1970-01-01
              • 1970-01-01
              • 2011-05-15
              相关资源
              最近更新 更多