前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >JavaScript 字符串中的 pad 方法!

JavaScript 字符串中的 pad 方法!

作者头像
前端小智@大迁世界
发布2020-09-07 14:31:56
1.2K0
发布2020-09-07 14:31:56
举报
文章被收录于专栏:终身学习者终身学习者

作者: Dmitri Pavlutin 译者:前端小智 来源:dmitripavlutin

点赞再看,养成习惯本文 GitHub https://github.com/qq44924588... 上已经收录,更多往期高赞文章的分类,也整理了很多我的文档,和教程资料。欢迎Star和完善,大家面试可以参照考点复习,希望我们一起有点东西。

ES2017 引入了字符串补全长度的功能。如果某个字符串不够指定长度,会在头部或尾部补全。padStart()用于头部补全,padEnd()用于尾部补全 ?。

代码语言:javascript
复制
const string = 'hi';

string.padStart(3, 'c'); // "chi"

string.padEnd(4, 'l'); // "hill"

语法

代码语言:javascript
复制
string.padStart(<maxLength>, <padString>)

string.padEnd(<maxLength>, <padString>)

了解参数

padEndpadStart接受相同的参数。

1. maxLength

最终字符串的长度。

代码语言:javascript
复制
const result = string.padStart(5);

result.length; // 5

当我看到这个时,也花了我一段时间来学习。 我一直以为maxLength是重复填充字符串参数的次数。 所以这里只想强调一下此参数是当前字符串需要填充到的目标长度,不是填充字符串重复的次数。如果这个数值小于当前字符串的长度,则返回当前字符串本身。

当然,我相信读者比我聪明多了,所以我确定你没有这种困惑 ?

2. padString

padString 表示填充字符串。如果字符串太长,使填充后的字符串长度超过了目标长度,则只保留最左侧的部分,其他部分会被截断。此参数的默认值是一个空格 " "(U+0020。

代码语言:javascript
复制
'hi'.padStart(5);

// 等价于
'hi'.padStart(5, ' ');

如果你传入的是一个空字符串,那么什么都不会填充。

代码语言:javascript
复制
const result = 'hi'.padStart(5, '');

result; // "hi"
result.length; // 2

如何处理其他数据类型

对于第二个参数padString,它接受一个string。如果我们试图给它传入其他数据类型。它会调用 toString方法强制转成一个字符串。我们来看看在不同的值类型上使用toString会发生什么。

代码语言:javascript
复制
// 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具有相同的行为)。

代码语言:javascript
复制
'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:

代码语言:javascript
复制
undefined.toString(); // TypeError: Cannot read property 'toString' of undefined

但当我们把undefined作为第二个参数传入padStart,会得到这个:

代码语言:javascript
复制
'SAM'.padStart(10, undefined);
// '       SAM'

所以上面说的 padString 参数会使用 toString 强制转成字符串使用,到这里感觉又不对了 ?。我们先来看下规范:

ECMAScript 规范 :如果填充的字符串是 undefined,该填充的字符串就会被规制成空格( 0x0020)。

好吧,我们更正一下, 除了undefined,否则传递的所有其他数据类型都将使用toString强制转成字符串。

如果 padString 超过 maxLength 怎么办?

如果 maxLength 数值小于等于当前字符串的长度,则返回当前字符串本身。

代码语言:javascript
复制
'hi'.padEnd(2, 'SAM');
// 'hi'

如果 maxLength 小于 padString 的长度,则 padString 会被截断。

代码语言:javascript
复制
'hi'.padEnd(7, 'SAMANTHA');
// 'hiSAMAN'

padStart/padEnd vs padLeft/padRight

trim 方法具有的别名。

  • trimLefttrimStart的别名
  • trimRighttrimStart的别名

但是对于字符串填充方法,没有别名。 因此,请勿使用padLeftpadRight,它们不存在。 这也是建议你不要使用trim别名的原因,这样让代码库中具有一致性 ?

实战用事

使用 padStart 让字符串右对齐
代码语言:javascript
复制
console.log('JavaScript'.padStart(15));
console.log('HTML'.padStart(15));
console.log('CSS'.padStart(15));
console.log('Vue'.padStart(15));

得到的结果

代码语言:javascript
复制
     JavaScript
           HTML
            CSS
            Vue
数字打码
代码语言:javascript
复制
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

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 语法
  • 了解参数
    • 1. maxLength
      • 2. padString
      • 如何处理其他数据类型
      • 处理 undefined
      • 如果 padString 超过 maxLength 怎么办?
      • padStart/padEnd vs padLeft/padRight
      • 实战用事
        • 使用 padStart 让字符串右对齐
          • 数字打码
          • 浏览器支持
          领券
          问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档