字符串的扩展
【字符串的扩展】
模板字符串
认识模板字符串
- 普通字符串:
1 | '字符串' |
- 模板字符串:
1 | `字符串` |
模板字符串与一般字符串的区别
- 对于普通用法没有区别
1 | const name1 = 'zjr'; |
- 字符串拼接的巨大区别
1 | const person = { |
1 | const person = { |
模板字符串最大的优势:方便注入!
模板字符串的注意事项
输出多行字符串
1 | // 一般字符串 |
模板字符串中,所有的空格、换行或缩进都会被保存在输出中
输出 `` 和
` 等特殊字符
1 | const info = `\``; // ``` |
模板字符串的注入
1 | const username = 'alex'; |
模板字符串的
${}
注入可以兼容几乎所有的值!模板字符串、字符串、数值、布尔值、表达式、函数……(只要结果是个 “值” 即可)
模板字符串的应用
1 | <!DOCTYPE html> |
alt=“image-20220315130229559”> style=“zoom:50%;” />
includes(), startsWith(), endsWith()
传统上,JavaScript 只有indexOf
方法,可以用来确定一个字符串是否包含在另一个字符串中。ES6 又提供了三种新方法。
- includes():返回布尔值,表示是否找到了参数字符串。
- startsWith():返回布尔值,表示参数字符串是否在原字符串的头部。
- endsWith():返回布尔值,表示参数字符串是否在原字符串的尾部。
1 | let s = 'Hello world!'; |
这三个方法都支持第二个参数,表示开始搜索的位置。
1 | let s = 'Hello world!'; |
上面代码表示,使用第二个参数n
时,endsWith
的行为与其他两个方法有所不同。它针对前n
个字符,而其他两个方法针对从第n
个位置直到字符串结束。
repeat()
repeat
方法返回一个新字符串,表示将原字符串重复n
次。
1 | 'x'.repeat(3) // "xxx" |
参数如果是小数,会被取整。
1 | 'na'.repeat(2.9) // "nana" |
如果repeat
的参数是负数或者Infinity
,会报错。
1 | 'na'.repeat(Infinity) |
但是,如果参数是 0 到-1 之间的小数,则等同于 0,这是因为会先进行取整运算。0 到-1 之间的小数,取整以后等于-0
,repeat
视同为 0。
1 | 'na'.repeat(-0.9) // "" |
参数NaN
等同于 0。
1 | 'na'.repeat(NaN) // "" |
如果repeat
的参数是字符串,则会先转换成数字。
1 | 'na'.repeat('na') // "" |
padStart(),padEnd()
ES2017 引入了字符串补全长度的功能。如果某个字符串不够指定长度,会在头部或尾部补全。padStart()
用于头部补全,padEnd()
用于尾部补全。
1 | 'x'.padStart(5, 'ab') // 'ababx' |
上面代码中,padStart()
和padEnd()
一共接受两个参数,第一个参数是字符串补全生效的最大长度,第二个参数是用来补全的字符串。
如果原字符串的长度,等于或大于最大长度,则字符串补全不生效,返回原字符串。
1 | 'xxx'.padStart(2, 'ab') // 'xxx' |
如果用来补全的字符串与原字符串,两者的长度之和超过了最大长度,则会截去超出位数的补全字符串。
1 | 'abc'.padStart(10, '0123456789') |
如果省略第二个参数,默认使用空格补全长度。
1 | 'x'.padStart(4) // ' x' |
padStart()
的常见用途是为数值补全指定位数。下面代码生成 10 位的数值字符串。
1 | '1'.padStart(10, '0') // "0000000001" |
另一个用途是提示字符串格式。
1 | '12'.padStart(10, 'YYYY-MM-DD') // "YYYY-MM-12" |
trimStart(),trimEnd()
trimStart()
和trimEnd()
这两个方法,它们的行为与trim()
一致,trimStart()
消除字符串头部的空格,trimEnd()
消除尾部的空格。它们返回的都是新字符串,不会修改原始字符串。
1 | const s = ' abc '; |
上面代码中,trimStart()
只消除头部的空格,保留尾部的空格。trimEnd()
也是类似行为。
除了空格键,这两个方法对字符串头部(或尾部)的 tab 键、换行符等不可见的空白符号也有效。
浏览器还部署了额外的两个方法,trimLeft()
是trimStart()
的别名,trimRight()
是trimEnd()
的别名。
at()
at()
方法接受一个整数作为参数,返回参数指定位置的字符,支持负索引(即倒数的位置)。
1 | const str = 'hello'; |
如果参数位置超出了字符串范围,at()
返回undefined
。