关于前端:JavaScript-字符串中的-pad-方法

41次阅读

共计 2862 个字符,预计需要花费 8 分钟才能阅读完成。

作者: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>)

理解参数

padEndpadStart 承受雷同的参数。

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'

// Boolean
true.toString();   // 'true'
false.toString();  // 'false'

// Array
['A'].toString(); // 'A'
[''].toString();  //''

// Object
({}).toString();         // '[object Object]'
({hi: 'hi'}).toString(); // '[object Object]'

有了这些常识,咱们看看是否能够将这些其余值类型传递给 padStartpadEnd 具备雷同的行为)。

'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 办法具备的别名。

  • trimLefttrimStart 的别名
  • trimRighttrimStart的别名

然而对于字符串填充办法,没有别名。因而,请勿应用 padLeftpadRight,它们不存在。这也是倡议你不要应用 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

浏览器反对

padStartpadEnd 是同时引入的,因而它们共享类似的浏览器反对,除了 IE 之外,都 能够用 ????


原文:https://dmitripavlutin.com/re…

代码部署后可能存在的 BUG 没法实时晓得,预先为了解决这些 BUG,花了大量的工夫进行 log 调试,这边顺便给大家举荐一个好用的 BUG 监控工具 Fundebug。

交换

干货系列文章汇总如下,感觉不错点个 Star,欢送 加群 互相学习。

https://github.com/qq44924588…

我是小智,公众号「大迁世界」作者,对前端技术放弃学习爱好者。我会常常分享本人所学所看的干货,在进阶的路上,共勉!

关注公众号,后盾回复 福利,即可看到福利,你懂的。

正文完
 0