有没有一种简单的方法可以在 JavaScript 中将文本转换为 HTML? [复制]
Posted
技术标签:
【中文标题】有没有一种简单的方法可以在 JavaScript 中将文本转换为 HTML? [复制]【英文标题】:Is there an easy way to convert text into HTML in JavaScript? [duplicate] 【发布时间】:2012-04-30 07:15:13 【问题描述】:可能重复:Escaping html strings with jQueryjavascript/jQuery HTML Encoding
例如,如果我想在 HTML 中向用户显示字符串 x < 3
,我需要将 &lt;
字符替换为 &lt;
。在 JavaScript 或 jQuery 中是否有预建函数可以将任何文本字符串转换为相应的 HTML?
【问题讨论】:
***.com/questions/24816/… ***.com/questions/6020714/escape-html-using-jquery 10 个答案...我可以再获得 2 票吗? 10 个答案...一定很简单。 不重复,因为问题是关于 JavaScript,而不是 Jquery 【参考方案1】:如果要使用jQuery,可以使用text(string)
方法。
$(".selector").text("x < 5");
http://api.jquery.com/text/
【讨论】:
【参考方案2】:或者,简单点,做这个
var str1 = "x < 3";
str1.replace(/</g, '<');
这是来自另一个问题的function
function htmlEscape(str)
return String(str)
.replace(/&/g, '&')
.replace(/"/g, '"')
.replace(/'/g, ''')
.replace(/</g, '<')
.replace(/>/g, '>');
或者,使用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 设置为:
<b></b> for bold!
然后您可以使用以下方法检索此 html:
$("div.test").html();
【讨论】:
【参考方案4】:你可以使用 jQuery 的力量:
var str = "x < 3";
str = $('<div>').text(str).html();
会给你"x &lt; 3"
结果。字符串"Alpha & Omega"
会变成"Alpha &amp; Omega"
等等。
【讨论】:
【参考方案5】:假设您已将字符串存储到变量中
k = " <!"#$\'";
那么当你需要“打印”这些值时使用
escape (k );
【讨论】:
而字符串'x < 3'
会变成x%20%3C%203
。
escape() 适用于网络传输,不适用于显示。
【参考方案6】:
有一个php函数名htmlentities,我为JS找到了这个:
function HTMLentities(texte)
texte = texte.replace(/"/g,'"'); // 34 22
texte = texte.replace(/&/g,'&'); // 38 26
texte = texte.replace(/\'/g,'''); // 39 27
texte = texte.replace(/</g,'<'); // 60 3C
texte = texte.replace(/>/g,'>'); // 62 3E
texte = texte.replace(/\^/g,'ˆ'); // 94 5E
texte = texte.replace(/‘/g,'‘'); // 145 91
texte = texte.replace(/’/g,'’'); // 146 92
texte = texte.replace(/“/g,'“'); // 147 93
texte = texte.replace(/”/g,'”'); // 148 94
texte = texte.replace(/•/g,'•'); // 149 95
texte = texte.replace(/–/g,'–'); // 150 96
texte = texte.replace(/—/g,'—'); // 151 97
texte = texte.replace(/˜/g,'˜'); // 152 98
texte = texte.replace(/™/g,'™'); // 153 99
texte = texte.replace(/š/g,'š'); // 154 9A
texte = texte.replace(/›/g,'›'); // 155 9B
texte = texte.replace(/œ/g,'œ'); // 156 9C
texte = texte.replace(//g,'ť'); // 157 9D
texte = texte.replace(/ž/g,'ž'); // 158 9E
texte = texte.replace(/Ÿ/g,'Ÿ'); // 159 9F
// texte = texte.replace(/ /g,' '); // 160 A0
texte = texte.replace(/¡/g,'¡'); // 161 A1
texte = texte.replace(/¢/g,'¢'); // 162 A2
texte = texte.replace(/£/g,'£'); // 163 A3
//texte = texte.replace(/ /g,'¤'); // 164 A4
texte = texte.replace(/¥/g,'¥'); // 165 A5
texte = texte.replace(/¦/g,'¦'); // 166 A6
texte = texte.replace(/§/g,'§'); // 167 A7
texte = texte.replace(/¨/g,'¨'); // 168 A8
texte = texte.replace(/©/g,'©'); // 169 A9
texte = texte.replace(/ª/g,'ª'); // 170 AA
texte = texte.replace(/«/g,'«'); // 171 AB
texte = texte.replace(/¬/g,'¬'); // 172 AC
texte = texte.replace(//g,'­'); // 173 AD
texte = texte.replace(/®/g,'®'); // 174 AE
texte = texte.replace(/¯/g,'¯'); // 175 AF
texte = texte.replace(/°/g,'°'); // 176 B0
texte = texte.replace(/±/g,'±'); // 177 B1
texte = texte.replace(/²/g,'²'); // 178 B2
texte = texte.replace(/³/g,'³'); // 179 B3
texte = texte.replace(/´/g,'´'); // 180 B4
texte = texte.replace(/µ/g,'µ'); // 181 B5
texte = texte.replace(/¶/g,'¶'); // 182 B6
texte = texte.replace(/·/g,'·'); // 183 B7
texte = texte.replace(/¸/g,'¸'); // 184 B8
texte = texte.replace(/¹/g,'¹'); // 185 B9
texte = texte.replace(/º/g,'º'); // 186 BA
texte = texte.replace(/»/g,'»'); // 187 BB
texte = texte.replace(/¼/g,'¼'); // 188 BC
texte = texte.replace(/½/g,'½'); // 189 BD
texte = texte.replace(/¾/g,'¾'); // 190 BE
texte = texte.replace(/¿/g,'¿'); // 191 BF
texte = texte.replace(/À/g,'À'); // 192 C0
texte = texte.replace(/Á/g,'Á'); // 193 C1
texte = texte.replace(/Â/g,'Â'); // 194 C2
texte = texte.replace(/Ã/g,'Ã'); // 195 C3
texte = texte.replace(/Ä/g,'Ä'); // 196 C4
texte = texte.replace(/Å/g,'Å'); // 197 C5
texte = texte.replace(/Æ/g,'Æ'); // 198 C6
texte = texte.replace(/Ç/g,'Ç'); // 199 C7
texte = texte.replace(/È/g,'È'); // 200 C8
texte = texte.replace(/É/g,'É'); // 201 C9
texte = texte.replace(/Ê/g,'Ê'); // 202 CA
texte = texte.replace(/Ë/g,'Ë'); // 203 CB
texte = texte.replace(/Ì/g,'Ì'); // 204 CC
texte = texte.replace(/Í/g,'Í'); // 205 CD
texte = texte.replace(/Î/g,'Î'); // 206 CE
texte = texte.replace(/Ï/g,'Ï'); // 207 CF
texte = texte.replace(/Ð/g,'Ð'); // 208 D0
texte = texte.replace(/Ñ/g,'Ñ'); // 209 D1
texte = texte.replace(/Ò/g,'Ò'); // 210 D2
texte = texte.replace(/Ó/g,'Ó'); // 211 D3
texte = texte.replace(/Ô/g,'Ô'); // 212 D4
texte = texte.replace(/Õ/g,'Õ'); // 213 D5
texte = texte.replace(/Ö/g,'Ö'); // 214 D6
texte = texte.replace(/×/g,'×'); // 215 D7
texte = texte.replace(/Ø/g,'Ø'); // 216 D8
texte = texte.replace(/Ù/g,'Ù'); // 217 D9
texte = texte.replace(/Ú/g,'Ú'); // 218 DA
texte = texte.replace(/Û/g,'Û'); // 219 DB
texte = texte.replace(/Ü/g,'Ü'); // 220 DC
texte = texte.replace(/Ý/g,'Ý'); // 221 DD
texte = texte.replace(/Þ/g,'Þ'); // 222 DE
texte = texte.replace(/ß/g,'ß'); // 223 DF
texte = texte.replace(/à/g,'á'); // 224 E0
texte = texte.replace(/á/g,'á'); // 225 E1
texte = texte.replace(/â/g,'â'); // 226 E2
texte = texte.replace(/ã/g,'ã'); // 227 E3
texte = texte.replace(/ä/g,'ä'); // 228 E4
texte = texte.replace(/å/g,'å'); // 229 E5
texte = texte.replace(/æ/g,'æ'); // 230 E6
texte = texte.replace(/ç/g,'ç'); // 231 E7
texte = texte.replace(/è/g,'è'); // 232 E8
texte = texte.replace(/é/g,'é'); // 233 E9
texte = texte.replace(/ê/g,'ê'); // 234 EA
texte = texte.replace(/ë/g,'ë'); // 235 EB
texte = texte.replace(/ì/g,'ì'); // 236 EC
texte = texte.replace(/í/g,'í'); // 237 ED
texte = texte.replace(/î/g,'î'); // 238 EE
texte = texte.replace(/ï/g,'ï'); // 239 EF
texte = texte.replace(/ð/g,'ð'); // 240 F0
texte = texte.replace(/ñ/g,'ñ'); // 241 F1
texte = texte.replace(/ò/g,'ò'); // 242 F2
texte = texte.replace(/ó/g,'ó'); // 243 F3
texte = texte.replace(/ô/g,'ô'); // 244 F4
texte = texte.replace(/õ/g,'õ'); // 245 F5
texte = texte.replace(/ö/g,'ö'); // 246 F6
texte = texte.replace(/÷/g,'÷'); // 247 F7
texte = texte.replace(/ø/g,'ø'); // 248 F8
texte = texte.replace(/ù/g,'ù'); // 249 F9
texte = texte.replace(/ú/g,'ú'); // 250 FA
texte = texte.replace(/û/g,'û'); // 251 FB
texte = texte.replace(/ü/g,'ü'); // 252 FC
texte = texte.replace(/ý/g,'ý'); // 253 FD
texte = texte.replace(/þ/g,'þ'); // 254 FE
texte = texte.replace(/ÿ/g,'ÿ'); // 255 FF
return texte;
【讨论】:
这看起来可行,但我认为它可能太耗时了。 我同意,这是一个完整的包来回答这个问题。【参考方案7】:这会替换 javascript 中的字符:
function replaceStr(str)
return str
.replace(/&/g, "&")
.replace(/</g, "<")
.replace(/>/g, ">")
.replace(/"/g, """)
.replace(/'/g, "'");
【讨论】:
【参考方案8】:您可以使用 php.js 库的一部分,它实现了从 php 到 js 的已知功能。还有大名鼎鼎的htmlspecialchars
:http://phpjs.org/functions/htmlspecialchars:426
显然,从函数中删除不必要的部分:)
也可以看看:HtmlSpecialChars equivalent in Javascript?
【讨论】:
【参考方案9】:如果您使用的是 jQuery,您可以按照这个答案的建议进行操作:
HTML-encoding lost when attribute read from input field
【讨论】:
以上是关于有没有一种简单的方法可以在 JavaScript 中将文本转换为 HTML? [复制]的主要内容,如果未能解决你的问题,请参考以下文章
有没有一种简单的方法可以从 JavaScript 或任何其他编程语言中的数组中进行随机选择?
JavaScript - 有没有一种简单的方法来获取嵌套 JSON 中每次出现的特定键的值
将 message.properties 暴露给 javascript?