javascript
内部,字符以UTF-16的格式存储,每个字符固定为2个字节,对于那些需要4个字节存储的字符,javascript
会认为他们是两个字符
字符串的遍历器接口
对于4字节的字符,length的长度会看作为2,for循环也会认为它是两个字符
而for…of循环可以准确的识别到这个字符
可以用字符串解构的方法回去到字符串的正确长度
let a = '😘'
[...a].length // 2
a.length // 1
includes(),startsWith(),endsWith()
includes
返回字符串,表示是否找到了参数字符串startsWith
返回布尔值,表示字符串是否在源字符串的头部endsWith
返回布尔值,表示参数字符串是否在源字符串的尾部
这3个方法都支持第二个参数,表示开始搜索的位置
repeat()
返回一个新字符串,表示把原字符串重复n次
- 如果为负数则会报错
- 如果是0,返回空串
indexOf()
indexOf()
方法,给定一个参数:要搜索的子字符串,搜索整个调用字符串,并返回指定子字符串第一次出现的索引。给定第二个参数:一个数字,该方法将返回指定子字符串在大于或等于指定数字的索引处的第一次出现。
indexOf(searchString)
indexOf(searchString, position)
// 如果 position 小于零,该方法的行为就像 position 为 0 时一样。
查找的字符串 searchValue 的第一次出现的索引,如果没有找到,则返回 -1
。
lastIndexOf()
lastIndexOf() 方法返回调用String 对象的指定值最后一次出现的索引,在一个字符串中的指定位置 fromIndex处从后向前搜索。如果没找到这个特定值则返回 -1。
str.lastIndexOf(searchValue[, fromIndex])
trim() trimEnd() trimStart()
trim() 方法从字符串的两端清除空格,返回一个新的字符串,而不修改原始字符串。此上下文中的空格是指所有的空白字符(空格、tab、不换行空格等)以及所有行终止符字符(如 LF、CR 等)。
toUpperCase() toLowerCase()
转换字符串的大小写
substring 和 slice
substring和slice都是从字符串中提取子串的方法。
这两个方法只会返回子串不会改变原字符串。
返回包含开始位置不包含结束位置的子串
substring(indexStart[, indexEnd]) | slice(indexStart[, indexEnd]) | |
---|---|---|
开始索引等于结束索引 | 返回空串 | 返回空串 |
省略结束索引 | 提取字符一直到字符串末尾 | 提取字符一直到字符串末尾 |
参数大于本身长度 | 当作strLength 处理 | 当作strLength 处理 |
任一参数小于0 | 当作0处理 | strLength + indexStart/indexEnd |
如果开始索引大于结束索引 | 前后参数调换 | 返回空串 |
split()
split() 方法使用指定的分隔符字符串将一个String对象分割成子字符串数组,以一个指定的分割字串来决定每个拆分的位置。
- 可以通过正则表达式来分割
- 如果使用空字符串 (“) 作为分隔符,则字符串不是在每个用户感知的字符 (图形素集群) 之间,也不是在每个 Unicode 字符 (代码点) 之间,而是在每个 UTF-16 代码单元之间。