JavaScript 字符串中的 pad 方法!

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

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

const string = 'hi' 
string.padStart(3, 'c'); // "chi"  
string.padEnd(4, 'l'); // "hill" 
  • 1.
  • 2.
  • 3.

语法

string.padStart(<maxLength><padString> 
string.padEnd(<maxLength><padString>
  • 1.
  • 2.

了解参数

padEnd和padStart接受相同的参数。

1. maxLength

最终字符串的长度。

const result = string.padStart(5);  
result.length; // 5 
  • 1.
  • 2.

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

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

2. padString

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

'hi'.padStart(5); 
 
// 等价于 
'hi'.padStart(5, ' '); 
  • 1.
  • 2.
  • 3.
  • 4.

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

const result = 'hi'.padStart(5, ''); 
 
result; // "hi" 
result.length; // 2 
  • 1.
  • 2.
  • 3.
  • 4.

如何处理其他数据类型

对于第二个参数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]' 
  • 1.
  • 2.
  • 3.
  • 4.
  • 5.
  • 6.
  • 7.
  • 8.
  • 9.
  • 10.
  • 11.
  • 12.
  • 13.
  • 14.

有了这些知识,我们看看是否可以将这些其他值类型传递给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' 
  • 1.
  • 2.
  • 3.
  • 4.
  • 5.
  • 6.
  • 7.
  • 8.
  • 9.
  • 10.

处理 undefined

这里有一个有趣的例子,如果你强制把 undefined 转成一个字符串,得到一个TypeError:

undefined.toString(); // TypeError: Cannot read property 'toString' of undefined 
  • 1.

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

'SAM'.padStart(10, undefined); 
// '       SAM' 
  • 1.
  • 2.

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

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

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

如果 padString 超过 maxLength 怎么办?

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

'hi'.padEnd(2, 'SAM'); 
// 'hi' 
  • 1.
  • 2.

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

'hi'.padEnd(7, 'SAMANTHA'); 
// 'hiSAMAN' 
  • 1.
  • 2.

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)); 
  • 1.
  • 2.
  • 3.
  • 4.

得到的结果:

JavaScript 
      HTML 
       CSS 
       Vue 
  • 1.
  • 2.
  • 3.
  • 4.

数字打码:

const bankNumber = '2222 2222 2222 2222'
const last4Digits = bankNumber.slice(-4); 
 
last4Digits.padStart(bankNumber.length, '*'); 
// ***************2222 
  • 1.
  • 2.
  • 3.
  • 4.
  • 5.

浏览器支持

padStart和padEnd是同时引入的,因此它们共享相似的浏览器支持, 除了 IE 之外,都 可以用。

本文转载自微信公众号「 大迁世界」,可以通过以下二维码关注。转载本文请联系****公众号。

【责任编辑:赵宁宁 TEL:(010)68476606】

责任编辑:赵宁宁 来源: 大迁世界
相关推荐

2020-10-16 18:35:53

JavaScript字符串正则表达式

2011-07-11 16:00:22

字符串拼接

2020-08-01 16:19:13

JavaScript字符串开发

2015-06-09 14:43:36

javascript操作字符串

2020-08-30 16:30:49

JavaScriptString Pad开发

2022-12-15 16:23:32

JavaScrip字符串开发

2020-05-14 10:24:41

YAML配置字符串

2021-05-18 09:08:18

字符串子串对象

2024-07-29 07:00:00

JavaScript字符串数组对象

2011-07-11 15:36:44

JavaScript

2010-06-04 14:59:06

MySQL数据库

2023-12-05 08:02:51

JavaScript字符串功能

2020-12-31 07:56:02

JavaScript 字符串技巧

2020-05-12 08:53:15

JavaScript字符串处理库

2010-06-28 15:18:51

SQL Server

2010-04-27 12:26:21

Unix字符串

2022-09-22 11:40:11

JavaScript数组开发

2019-12-25 15:41:50

JavaScript程序员编程语言

2020-12-07 06:38:32

JavaScriptEval 函数

2021-03-26 08:36:35

JavaScript字符串开发
点赞
收藏

51CTO技术栈公众号