JS 字符串正确处理填坑
1.字符串长度判断
charAt()
method returns a new string consisting of the single UTF-16 code unit located at the specified offset into the string.
返回对应位置的16进制的单元 所表示的字符 就是说读两个字节
length()
The length
property of a String
object indicates the length of a string, in UTF-16 code units.
2.字符集
JavaScript 使用 Unicode 字符集。
- 字符表示:JavaScript 引擎内部,所有字符都用 Unicode 表示
- 字符储存:JavaScript 不仅以 Unicode 储存字符,还允许直接在程序中使用 Unicode 码点表示字符,即将字符写成\uxxxx的形式,其中xxxx代表该字符的 Unicode 码点。比如,\u00A9代表版权符号
解析代码的时候,JavaScript 会自动识别一个字符是字面形式表示,还是 Unicode 形式表示。输出给用户的时候,所有字符都会转成字面形式。
每个字符在 JavaScript 内部都是以16位(即2个字节)的 UTF-16 格式储存
但是,UTF-16 有两种长度:对于码点在U+0000到U+FFFF之间的字符,长度为16位(即2个字节);
对于码点在U+10000到U+10FFFF之间的字符,长度为32位(即4个字节),而且前两个字节在0xD800到0xDBFF之间,后两个字节在0xDC00到0xDFFF之间。举例来说,码点U+1D306对应的字符为𝌆,它写成 UTF-16 就是0xD834 0xDF06。
JavaScript 对 UTF-16 的支持是不完整的,由于历史原因,只支持两字节的字符,不支持四字节的字符。
这是因为 JavaScript 第一版发布的时候,Unicode 的码点只编到U+FFFF,因此两字节足够表示了。后来,Unicode 纳入的字符越来越多,出现了四字节的编码。但是JavaScript 的标准此时已经定型了,统一将字符长度限制在两字节,导致无法识别四字节的字符。上一节的那个四字节字符𝌆,浏览器会正确识别这是一个字符,但是 JavaScript 无法识别,会认为这是两个字符。
也就是说,JavaScript 返回的字符串长度可能是不正确的。
http://javascript.ruanyifeng.com/grammar/string.html base64 还没看
image.pngwindow对象下属性分为两类
- ECMA规定
- 私有的,chrome ,Firefox,比如prompt,alert,confirm。
Number函数 生成一个number对象,内存效果不一样
普通声明 var a = 1; a想用number对象的属性,那么可以直接调用,自动做操作temp = new Number(a), 然后temp.tostring();就可以干掉temp
image.png
对象的公用属性,让同类对象的公用属性收拢
用proto:指向原型对象