ES2017 引入了字符串补全长度的功能。如果某个字符串不够指定长度,会在头部或尾部补全。padStart()
用于头部补全,padEnd()
用于尾部补全
const string = 'hi';
string.padStart(3, 'c'); // "chi"
string.padEnd(4, 'l'); // "hill"
语法
string.padStart(<maxLength>, <padString>)
string.padEnd(<maxLength>, <padString>)
了解参数
1. maxLength 最终字符串的长度。
const result = string.padStart(5);
result.length; // 5
2. padString表示填充字符串。如果字符串太长,使填充后的字符串长度超过了目标长度,则只保留最左侧的部分,其他部分会被截断。此参数的默认值是一个空格 " "
'hi'.padStart(5);
// 等价于
'hi'.padStart(5, ' ');
如果你传入的是一个空字符串,那么什么都不会填充
const result = 'hi'.padStart(5, '');
result; // "hi"
result.length; // 2
如何处理其他数据类型
对于第二个参数padString,它接受一个string。如果我们试图给它传入其他数据类型。它会调用 toString方法强制转成一个字符串。我们来看看在不同的值类型上使用toString会发生什么。
// Number
(100).toString(); // '100'
// Boolean
true.toString(); // 'true'
false.toString(); // 'false'
// Array
['A'].toString(); // 'A'
[''].toString(); // ''
// Object
({}).toString(); // '[object Object]'
({hi: 'hi'}).toString(); // '[object Object]'
有了这些知识,我们看看是否可以将这些其他值类型传递给padStart
(padEnd
具有相同的行为)。
'SAM'.padStart(8, 100); // '10010SAM'
'SAM'.padStart(8, true); // 'truetSAM'
'SAM'.padStart(8, false); // 'falseSAM'
'SAM'.padStart(5, ['']); // 'SAM'
'SAM'.padStart(5, ['hi']); // 'hiSAM'
'SAM'.padStart(18, {}); // '[object Object]SAM'
'SAM'.padStart(18, {hi: 'hi'}); // '[object Object]SAM'
处理 undefined
这里有一个有趣的例子,如果你强制把 undefined 转成一个字符串,得到一个TypeError:
undefined.toString(); // TypeError: Cannot read property 'toString' of undefined
但当我们把undefined作为第二个参数传入padStart,会得到这个:
'SAM'.padStart(10, undefined);
// ' SAM'
//除了undefined,否则传递的所有其他数据类型都将使用toString强制转成字符串。
如果 padString 超过 maxLength 怎么办?
'hi'.padEnd(2, 'SAM');
// 'hi'
如果 maxLength小于 padString的长度,则 padString 会被截断。
'hi'.padEnd(7, 'SAMANTHA');
// 'hiSAMAN'
使用 padStart 让字符串右对齐
console.log('JavaScript'.padStart(15));
console.log('HTML'.padStart(15));
console.log('CSS'.padStart(15));
console.log('Vue'.padStart(15));
//JavaScript
// HTML
// CSS
// Vue