String.fromCodePoint()
优点:
用于从 Unicode 码点返回对应字符 ,弥补ES5 提供的String.fromCharCode()
方法的不足(不能识别码点大于0xFFFF的字符)
用法:
String.fromCodePoint(0x20BB7)
// "𠮷"
String.fromCodePoint(0x78, 0x1f680, 0x79) === 'x\uD83D\uDE80y'
// true
上面代码中,如果String.fromCodePoint
方法有多个参数,则它们会被合并
成一个字符串返回。
注意,fromCodePoint
方法定义在String
对象上,而codePointAt
方法定义在字符串的实例对象上。
String. raw()
优点:
返回一个斜杠都被转义(即斜杠前面再加一个斜杠)的字符串
使用场景:
用于模板字符串
的处理方法
缺点:
如果原字符串的斜杠已经转义,那么String.raw()
会进行再次转义。
用法:
String.raw`Hi\n${2+3}!`
// 实际返回 "Hi\\n5!",显示的是转义后的结果 "Hi\n5!"
String.raw`Hi\u000A!`;
// 实际返回 "Hi\\u000A!",显示的是转义后的结果 "Hi\u000A!"
// 再次转译
String.raw`Hi\\n`
// 返回 "Hi\\\\n"
String.raw`Hi\\n` === "Hi\\\\n" // true
String.raw()
本质上是一个正常的函数,只是专用于模板字符串的标签函数
。如果写成正常函数的形式,它的第一个参数,应该是一个具有raw属性的对象,且raw属性的值应该是一个数组,对应模板字符串解析后的值。
// `foo${1 + 2}bar`
// 等同于
String.raw({ raw: ['foo', 'bar'] }, 1 + 2) // "foo3bar"
作为函数的用法:
String.raw = function (strings, ...values) {
let output = '';
let index;
for (index = 0; index < values.length; index++) {
output += strings.raw[index] + values[index];
}
output += strings.raw[index]
return output;
}
codePointAt()
作用
弥补ES5
的charAt()
方法无法读取完整字符(只能读取2个字节)
测试一个字符由两个字节还是由四个字节组成的最简单方法
codePointAt()
方法返回的是码点的十进制值
(返回 32 位的 UTF-16 字符的码点),如果想要十六进制的值
,可以使用toString()
方法转换一下。
使用方式
// 十进制值
let s = '𠮷a';
s.codePointAt(0).toString(16) // "20bb7"
s.codePointAt(2).toString(16) // "61"
// 十六进制值
s.codePointAt(0).toString(16) // "20bb7"
s.codePointAt(2).toString(16) // "61"
注意上面的,codePointAt()方法的参数,仍然是不正确的。比如,上面代码中,字符a在字符串s的正确位置序号应该是 1,但是必须向codePointAt()方法传入 2。解决这个问题的一个办法是使用for...of循环,因为它会正确识别 32 位的 UTF-16 字符。
let s = '𠮷a';
for (let ch of s) {
console.log(ch.codePointAt(0).toString(16));
}
// 20bb7
// 61
另一种方法也可以,使用扩展运算符(...
)进行展开运算。
let arr = [...'𠮷a']; // arr.length === 2
arr.forEach(
ch => console.log(ch.codePointAt(0).toString(16))
);
// 20bb7
// 61
测试一个字符由两个字节还是由四个字节组成的方法
function is32Bit(c) {
return c.codePointAt(0) > 0xFFFF;
}
is32Bit("𠮷") // true
is32Bit("a") // false
normalize(略,没看懂)
实例方法():includes(), startsWith(), endsWith()
传统上,JavaScript 只有indexOf
方法,可以用来确定一个字符串是否包含在另一个字符串中。ES6 又提供了三种新方法。
- includes():返回布尔值,表示是否找到了参数字符串。
- startsWith():返回布尔值,表示参数字符串是否在原字符串的头部。
- endsWith():返回布尔值,表示参数字符串是否在原字符串的尾部。
let s = 'Hello world!';
s.startsWith('Hello') // true
s.endsWith('!') // true
s.includes('o') // true
这三个方法都支持第二个参数,表示开始搜索的位置
let s = 'Hello world!';
s.startsWith('world', 6) // true
s.endsWith('Hello', 5) // true
s.includes('Hello', 6) // false
上面代码表示,使用第二个参数n
时,endsWith
的行为与其他两个方法有所不同。它针对前n
个字符,而其他两个方法针对从第n
个位置直到字符串结束。
实例方法:repeat()
repeat
方法返回一个新字符串,表示将原字符串重复n
次
注意:
- 参数如果是小数,会被向下取整(1.9 => 1 ; 0.9 => 0)
- 如果repeat的参数是负数或者Infinity,会报错
- 参数NaN等同于 0。
- 如果repeat的参数是数字字符串,则会转换成数字;如果是字母、汉字、中英文字母,则会转成0
'x'.repeat(3) // "xxx"
'hello'.repeat(2) // "hellohello"
'na'.repeat(0) // ""
// 小数取整
'na'.repeat(2.9) // "nana"
// 负数或者Infinity
'na'.repeat(Infinity)
// RangeError
'na'.repeat(-1)
// RangeError
//报错
'na'.repeat(-0.9) // ""
//参数NaN等同于 0
'na'.repeat(NaN) // ""
//参数是字符串,则会先转换成数字
'na'.repeat('na') // ""
'na'.repeat('3') // "nanana"
实例方法:trimStart(),trimEnd()
- 这两个方法与
trim()
功能一致,trimStart()
消除字符串头部的空格,trimEnd()
消除尾部的空格。它们返回的都是新字符串,不会修改原始字符串 - 浏览器还部署了额外的两个方法,
trimLeft()
是trimStart()
的别名,trimRight()
是trimEnd()
的别名。
const s = ' abc ';
s.trim() // "abc"
s.trimStart() // "abc "
s.trimEnd() // " abc"
trimStart()
只消除头部的空格,保留尾部的空格。trimEnd()
也是类似行为。
除了空格键,这两个方法对字符串头部(或尾部)的 tab 键、换行符等不可见的空白符号也有效。
实例方法:matchAll()
matchAll()
方法返回一个正则表达式在当前字符串的所有匹配
网友评论