是否可以在 JavaScript 的 alert()
、confirm()
或 prompt()
对话框中显示上标字符(不仅仅是数字) ?
由于某些原因,我需要插入文本:
2 后跟上标“n”
2^n
进入 JavaScript 警报、确认和提示框。快速谷歌搜索确实有帮助,但不完全是我找到了一种使用 Unicode \u00B 字符在对话框中显示上标数字的方法,但它不适用于字符
alert('2\u00B2'); shows correctly 2^2
alert('2\u00Bn'); shows 2u00Bn
所以目标是显示上标字符而不是数字。
^ 用作 Power 并显示下一个字符是上标,以防万一有人感到困惑。
Is it possible to display superscripted characters (not only numbers) in the alert()
, confirm()
or prompt()
dialogue boxes in JavaScript?
Due to some reasons I need to insert a text:
2 followed by superscripted 'n'
2^n
Into JavaScript alert, confirm and prompt boxes. Fast google searching did help but not exactly I found a way to display superscripted numbers in dialogue boxes using Unicode \u00B character but it doesn't work with characters
alert('2\u00B2'); shows correctly 2^2
alert('2\u00Bn'); shows 2u00Bn
So the goal is to show a character superscripted not the number.
^ is used as Power and to show that next character is superscripted, just in case someone gets confused.
发布评论
评论(5)
该字符代码没有什么神奇之处 - 它只是恰好是为“上标二”字符选择的代码。还有一个“上标三”(
\u00B3
) (³)、一个“上标一”(\00B9
) (¹) 和一个“上标拉丁小写字母 N” (\u207F
) (ⁿ)。但如果您需要其他上标,那么您就不走运了 -alert()
不会呈现 HTML,因此您只能使用 Unicode 定义的字符。您最好完全放弃
alert()
并在页面本身内模拟模式对话框。许多库已经提供了此功能,包括优秀的 jQuery UI Dialog。There's nothing magical about that character code - it just happens to be the one picked for the "Superscript two" character. There's also a "Superscript three" (
\u00B3
) (³) a "Superscript one" (\00B9
) (¹), and a "Superscript Latin Small Letter N" (\u207F
) (ⁿ). But if you need some other superscript, you're out of luck -alert()
doesn't render HTML, so you're limited to the characters defined by Unicode.You might be better off abandoning
alert()
entirely, and simulating a modal dialog within the page itself. Many libraries exist to provide this functionality already, including the excellent jQuery UI Dialog.不,没有可靠的方法将上标文本放入警报框中。您当然可以使用 HTML
标记在页面上执行此操作,但在警报框中您会受到更多限制。
问题是:没有“Unicode
\u00B
”字符。您使用的字符是\u00B2
(定义为“上标二”)。事实上最后有一个“2”本质上是巧合。例如,代码点\u00B1
是不相关的(它是加号/减号)。还有一些其他字符在 Unicode 中具有特定的上标版本,您可以在 此搜索,但并非每个字母都有上标版本。
No, there's no reliable way of getting superscript text into an alert box. You could certainly do it on the page using the HTML
<sup>
tag, but in an alert box you're more limited.The problem is: there is no "Unicode
\u00B
" character. The character you're using is\u00B2
(defined as "Superscript Two"). The fact that there's a two at the end is essentially coincidental. The code point\u00B1
, for example, is unrelated (it's the plus/minus sign).There are a few other characters that have specific superscript versions in Unicode, which you can find in this search, but there aren't superscript versions of every letter.
Unicode,或UTF-8需要两对字符,或四个十六进制数字来组成一个字符;
00B2
被识别为“上标 2”,而00Bn
是无效的十六进制值。上标数字 1-3 为:00B9
、00B2
和00B3
。不幸的是,没有神奇的上标前缀可以使后面的字符成为上标。只有 HTML
可以做到这一点,并且正如 Shog 所说,alert 呈现纯文本。
Unicode, or UTF-8 requires two pairs of characters, or four hexadecimal digits to make a character;
00B2
is recognized as "superscript 2" whereas00Bn
is an invalid hexadecimal value. The superscript numbers 1-3 are:00B9
,00B2
, and00B3
.Unfortunately there is no magical superscript-prefix that will make the following character superscript. Only HTML
<sup>
can do that and, like Shog said, alert renders plain text.我最终编写了这段代码来生成 unicode 上标整数:
如果您还需要其他字符, 这篇博文列出了大多数(但不是全部)大写和小写上标 unicode 字母,并且扩展上面的代码以处理其他字符相对简单。
I ended up writing this code for generating unicode superscript integers:
If you need other characters as well, this blog post lists most, but not all uppercase and lowercase superscript unicode letters, and it's relatively straightforward to extend the code above so it handles other characters.
npm 包 numbers-to-superscript 将指定字符串中的所有数字转换为上标。
这里可能是一个选择。
The npm package numbers-to-superscript converts all numbers in the specified string to superscript.
Might be an option here.