前言
在js中我们对字符串进行一部分截取,可以使用slice()
函数截取,也可以直接用substring()
函数来截取,但是截取也有可能出bug
const str='小𠮷和小𧨁今天吃了50块钱的KFC'
console.log(str.slice(0,5));
可以在控制台看到,本来应该截取的字符串是’小𠮷和小𧨁’才对,却少了一个字,这是什么原因呢?
js的字符编码
在很早的时候,js使用的编码规范是16位的字符编码(USC-2),规定了每一个字对应16位的空间,16位的空间称为码元,字符串的所有属性和方法(像是 length 属性和 chatAt 方法)都是基于 16 位的码元,但是后来生僻字越来越多,16位的空间不够用了
就把编码方式换成了utf-16,utf-16允许一个文字占用16位的空间也就是一个码元或者32位的空间就是两个码元,一些特殊的文字就占用了两个码元,像’𠮷’和’𧨁’就占用了两个码元