作者: Dmitri Pavlutin
译者:前端小智
起源:dmitripavlutin
点赞再看,养成习惯本文
GitHub
https://github.com/qq44924588... 上曾经收录,更多往期高赞文章的分类,也整顿了很多我的文档,和教程材料。欢送Star和欠缺,大家面试能够参照考点温习,心愿咱们一起有点货色。
ES2017 引入了字符串补全长度的性能。如果某个字符串不够指定长度,会在头部或尾部补全。padStart()
用于头部补全,padEnd()
用于尾部补全 ????。
const string = 'hi';string.padStart(3, 'c'); // "chi"string.padEnd(4, 'l'); // "hill"
语法
string.padStart(<maxLength>, <padString>)string.padEnd(<maxLength>, <padString>)
理解参数
padEnd
和padStart
承受雷同的参数。
1. maxLength
最终字符串的长度。
const result = string.padStart(5);result.length; // 5
当我看到这个时,也花了我一段时间来学习。 我始终认为maxLength
是反复填充字符串参数的次数。 所以这里只想强调一下
此参数是以后字符串须要填充到的指标长度,不是填充字符串反复的次数
。如果这个数值小于以后字符串的长度,则返回以后字符串自身。
当然,我置信读者比我聪慧多了,所以我确定你没有这种困惑 ????
2. padString
padString
示意填充字符串。如果字符串太长,使填充后的字符串长度超过了指标长度,则只保留最左侧的局部,其余局部会被截断。此参数的默认值是一个空格 " "
(U+0020。
'hi'.padStart(5);// 等价于'hi'.padStart(5, ' ');
如果你传入的是一个空字符串,那么什么都不会填充。
const result = 'hi'.padStart(5, '');result; // "hi"result.length; // 2
如何解决其余数据类型
对于第二个参数padString
,它承受一个string
。如果咱们试图给它传入其余数据类型。它会调用 toString
办法强制转成一个字符串。咱们来看看在不同的值类型上应用toString
会产生什么。
// Number(100).toString(); // '100'// Booleantrue.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'
所以下面说的 padString
参数会应用 toString
强制转成字符串应用,到这里感觉又不对了 ????。咱们先来看下标准:
ECMAScript 标准 :如果填充的字符串是 undefined
,该填充的字符串就会被规制成空格( 0x0020)。
好吧,咱们更正一下, 除了undefined
,否则传递的所有其余数据类型都将应用toString
强制转成字符串。
如果 padString 超过 maxLength 怎么办?
如果 maxLength
数值小于等于以后字符串的长度,则返回以后字符串自身。
'hi'.padEnd(2, 'SAM');// 'hi'
如果 maxLength
小于 padString
的长度,则 padString
会被截断。
'hi'.padEnd(7, 'SAMANTHA');// 'hiSAMAN'
padStart/padEnd vs padLeft/padRight
trim
办法具备的别名。
trimLeft
是trimStart
的别名trimRight
是trimStart
的别名
然而对于字符串填充办法,没有别名。 因而,请勿应用padLeft
和padRight
,它们不存在。 这也是倡议你不要应用trim
别名的起因,这样让代码库中具备一致性 ????
实战用事
应用 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
数字打码
const bankNumber = '2222 2222 2222 2222';const last4Digits = bankNumber.slice(-4);last4Digits.padStart(bankNumber.length, '*');// ***************2222
浏览器反对
padStart
和padEnd
是同时引入的,因而它们共享类似的浏览器反对, 除了 IE 之外,都 能够用 ????
原文:https://dmitripavlutin.com/re...
代码部署后可能存在的BUG没法实时晓得,预先为了解决这些BUG,花了大量的工夫进行log 调试,这边顺便给大家举荐一个好用的BUG监控工具 Fundebug。
交换
干货系列文章汇总如下,感觉不错点个Star,欢送 加群 互相学习。
https://github.com/qq44924588...
我是小智,公众号「大迁世界」作者,对前端技术放弃学习爱好者。我会常常分享本人所学所看的干货,在进阶的路上,共勉!
关注公众号,后盾回复福利,即可看到福利,你懂的。