- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试遍历 Javascript 字符串中的 Unicode 字符,我假设它是用 UTF-16 编码的。
据我了解,UTF-16 是可变宽度。也就是说,单个 Unicode 字符可以拆分为多个 16 位字符。我可以使用 s[i].codePointAt
获取从给定代码点开始的 Unicode 字符。但是一旦我拥有它,我怎么知道我要前进多远?
粗略地说,这里的getWidth
是什么?它只是 c > Math.pow(2, 16)
吗?
for (var i = 0; i < s.length;) {
var c = s.codePointAt(i);
// do some operation with c
i = i + getWidth(c)
}
是否有一个标准库函数可以用来确定前进的距离?或者迭代字符串中 Unicode 代码点的方法?
最佳答案
Is there a standard […] way to iterate over the Unicode code points in a string?
是的,从 ES6 开始你可以简单地 iterate获取代码点的所有字符串:
for (const character of string) {
const codepoint = character.codePointAt(0);
// do some operation with codepoint
}
关于javascript - 如何确定 codePointAt 结果的宽度?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45475216/
在 javascript 中有一个函数 codePointAt它返回一个数字,表示给定索引处字符的代码点值。是否有类似于 codePointAt 函数的 UDF 或内置函数? var icons =
我正在尝试遍历 Javascript 字符串中的 Unicode 字符,我假设它是用 UTF-16 编码的。 据我了解,UTF-16 是可变宽度。也就是说,单个 Unicode 字符可以拆分为多个 1
为什么下面的程序打印错误,我必须做哪些更改才能使其打印正确? public class Main { static int[] codePoints(String s) { i
如果我使用从 33 到 127 的任何 ASCII 字符,codePointAt 方法会给出正确的十进制值,例如: String s1 = new String("#"); int val = s1.
最近我遇到了codePointAt Java中String的方法。我还发现了其他一些 codePoint 方法:codePointBefore、codePointCount 等。它们肯定与 Unico
String.prototype.codePointAt() 和有什么区别和 String.prototype.charCodeAt()在 JavaScript 中? 'A'.codePointAt(
我在 JAVA 中有这段代码并且工作正常 String a = "ABC"; System.out.println(a.length()); for (int n = 0; n
从 Firefox 29 版本开始,Mozilla 提供 String.fromCodePoint和 String#codePointAt方法,并在各自的 MDN 页面上发布了 polyfill。 所
(以免因为过于本地化而关闭,我选择了 Ꙭ 作为示例,但许多其他字符也会出现这种情况) 字符 Ꙭ 是\uA66C 或十进制的 42604 ( http://unicodinator.com/#A66C
我是一名优秀的程序员,十分优秀!