JavaScript中的String Pad

开发 前端
填充非常容易!只需输入您想要的字符串和长度即可。它将填充字符串,直到达到长度为止。使用padStart在开始处应用它,使用padEnd在结尾处应用它 。

填充非常容易!只需输入您想要的字符串和长度即可。它将填充字符串,直到达到长度为止。使用padStart在开始处应用它,使用padEnd在结尾处应用它 。

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

语法

这是如何使用该方法的语法。

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

了解参数

padEnd 和 padStart 接受相同的参数。

(1) maxLength

这是结果字符串的最大长度。

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

当我学习这个时,这花了我一段时间,我一直认为这是重复填充字符串参数的次数。所以只想强调一下,这个参数是设置结果字符串的MAX或目标长度。这不是填充字符串重复的次数。但是你比我聪明,所以我确定你没有这种困惑

(2) padString

这是你想用来填充字符串的字符串。这是可选的。如果你未指定任何内容,则默认值为空白。

  1. 'hi'.padStart(5); 
  2. // 等同于 
  3. 'hi'.padStart(5, ' '); 

而且,如果你尝试传递一个空字符串,则不会发生填充。

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

它如何处理其他数据类型

对于第二个参数 padString,它接受一个字符串。如果你尝试传递任何其他数据类型,它将会使用 toString 将其强制为字符串,并将使用该字符串。因此,让我们看看在不同的值类型上使用 toString 时会发生什么。

  1. // NUMBER 
  2. (100).toString(); // '100' 
  3. // BOOLEAN 
  4. true.toString();   // 'true' 
  5. false.toString();  // 'false' 
  6. // ARRAY 
  7. ['A'].toString(); // 'A' 
  8. [''].toString();  // '' 
  9. // OBJECT 
  10. ({}).toString();         // '[object Object]' 
  11. ({hi: 'hi'}).toString(); // '[object Object]' 

现在知道了,让我们看看是否将这些其他值类型传递给padStart(padEnd将具有相同的行为)。

  1. 'SAM'.padStart(8, 100);    // '10010SAM' 
  2. 'SAM'.padStart(8, true);   // 'truetSAM' 
  3. 'SAM'.padStart(8, false);  // 'falseSAM' 
  4. 'SAM'.padStart(5, ['']);   // 'SAM' 
  5. 'SAM'.padStart(5, ['hi']); // 'hiSAM' 
  6. 'SAM'.padStart(18, {});         // '[object Object]SAM' 
  7. 'SAM'.padStart(18, {hi: 'hi'}); // '[object Object]SAM' 

处理undefined

但这里有一个有趣的问题。当你试图强制转换 undefined 的时候,你会得到一个 TypeError。

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

但是,当你传入 undefined 作为第二个参数时,你会得到以下结果:

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

所以当我说 padString 参数会用 toString 来强制转换的时候,我是不是骗了你好吧,我们来深入了解一下规范。

好吧,让我更新我的发言!除非是undefined,否则你传递的所有其他数据类型都将使用 toString 强制转换 。

如果padString超过maxLength怎么办?

当第一个参数 maxLength 不允许你的第一个参数padString有足够的长度时,它将被直接忽略。

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

或者,会将其切断。请记住,maxLength 表示你的 padString 可以占用的最大长度减去该字符串所占用的长度。

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

而且,如果你的第一个参数 maxLength 小于你的字符串,它将仅返回该字符串。

  1. 'hello'.padEnd(1, 'SAM'); 
  2. // 'hello' 

在之前的代码笔记中,我介绍了String Trim,其中提到了trim方法具有别名。

  • trimLeft是trimStart的别名
  • trimRight是trimEnd的别名

但是对于字符串填充方法,没有别名。所以不要使用 padLeft 和 padRight,它们不存在。这也是为什么鼓励你不要使用trim别名的原因,这样在你的代码库中有更好的一致性。

用例

(1) 使用padEnd进行表格格式设置

字符串填充方法的一个很好的用例是格式化。我介绍了如何以表格格式显示字符串。

(2) 用padStart右对齐字符串

你可以使用 padStart 格式化右对齐。

  1. console.log('JavaScript'.padStart(15)); 
  2. console.log('HTML'.padStart(15)); 
  3. console.log('CSS'.padStart(15)); 
  4. console.log('Vue'.padStart(15)); 

这将输出:

  1. JavaScript 
  2.            HTML            CSS            Vue 

(3) 收据格式

有了正确的对齐格式知识,你就可以像这样打印收据:

  1. const purchase = [ 
  2.   ['Masks', '9.99'], 
  3.   ['Shirt', '20.00'], 
  4.   ['Jacket', '200.00'], 
  5.   ['Gloves', '10.00'], 
  6. ];purchase.forEach(([item, price]) => { 
  7.   return console.log(item + price.padStart(20 - item.length)); 
  8. }); 

这将输出:

  1. Masks           9.99 
  2. Shirt          20.00 
  3. Jacket        200.00 
  4. Gloves         10.00 

(4) 掩盖数字

我们也可以使用它来显示被屏蔽的数字。

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

浏览器支持

padStart和padEnd是同时推出的,所以它们共享类似的浏览器支持。除了IE之外,所有的浏览器都支持,但是我们真的很惊讶吗?

Polyfill

对于IE或更旧的浏览器支持,请参阅此polyfill:

https://github.com/behnammodi/polyfill/blob/master/string.polyfill.js

 

责任编辑:赵宁宁 来源: 今日头条
相关推荐

2020-09-03 10:13:49

JavaScript字符串pad

2010-08-23 09:56:58

撕裂Wintel

2014-01-03 09:13:39

JavaScriptthis

2013-05-08 10:36:07

JavaScriptJS详解JavaScrip

2012-04-05 13:37:10

JavaString

2020-06-18 09:16:20

JavaScript缓存API

2015-07-23 11:59:27

JavascriptPromise

2022-12-29 08:54:53

依赖注入JavaScript

2021-10-21 18:47:37

JavaScript面向对象

2020-07-29 09:13:28

JavaScript开发技术

2017-03-20 14:45:42

JavaScript详解

2017-05-23 15:47:04

JavaScriptthis解析

2012-03-09 10:02:29

Java

2011-06-01 14:01:45

JavaString

2022-03-18 09:42:54

JavaString

2012-07-25 13:25:11

ibmdw

2021-02-05 07:33:05

JavaScript参数ES6

2020-08-23 11:32:21

JavaScript开发技术

2021-02-07 22:59:55

JavaScript编程方法链

2022-03-31 10:05:32

JavaScriptInfinity变量
点赞
收藏

51CTO技术栈公众号