ES2017 引入了字符串补全长度的功能。如果某个字符串不够指定长度,会在头部或尾部补全。padStart()
用于头部补全,padEnd()
用于尾部补全 ?。
const string = 'hi';
string.padStart(3, 'c'); // "chi"
string.padEnd(4, 'l'); // "hill"
语法
string.padStart(, )
string.padEnd(, )
了解参数
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'
// Boolean
true.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 之外,都 可以用 ?
作者:Dmitri Pavlutin 译者:前端小智 来源:dmitripavlutin 原文:https://dmitripavlutin.com/replace-all-string-occurrences-javascript/ 相关推荐
【面经分享】好未来-北京-视频面试
大厂面试过程复盘(微信/阿里/头条,附答案篇)
前端面试高频手写代码题
58道Vue常见面试题集锦,涵盖入门到精通,自测 Vue 掌握程度
前端面试128问汇总(含超详细答案)
15道TypeScript练习题 [中篇]
如何和面试官吹嘘一下我的Vue项目性能优化「面试必问」leetcode高频题精选
经常需要谷哥的ccs问题完美方案汇总
前端的你该如何学习算法?【面试准备】每日前端面试题 - 55(百度面试题)【面试准备】每日前端面试题 - 54(字节面试题) 【面试准备】每日前端面试题 - 53(字节面试题)【面试准备】每日前端面试题 - 52(动态规划算法题)
【面试准备】每日前端面试题 - 51 (字节面试题)
【面试准备】每日前端面试题 - 50 (字节面试题)
【面试准备】每日前端面试题 - 49 (字节面试题)
【面试准备】每日前端面试题 - 48 (美团校招面试)
【面试准备】每日前端面试题 - 47 (校招滴滴面试)
移动端1px问题应该如何解决?
为什么我们要熟悉这些通信协议?【精读】
前端面向对象,高阶JS应用!
面试前必读!!!原生JS补给(上)
前端p6笔试题,你可以答上多少个?
每天都在用class,你到底对它了解多小?
前端工程师必须掌握的几个JavaScript设计模式及场景应用
【JS进阶深挖】完全弄懂数据类型转换(下)
【收藏系列】JS灵魂之问(下) - 附个人成长经验分享
【收藏系列】JS灵魂之问, 是否有offer看你接到多少个(中)
【收藏系列】JS灵魂之问, 请问你能接得住几个?(上)
【大厂面试】20道超高频题目 【JS进阶深挖】完全弄懂数据类型转换(上) 前端架构师最终面试题!48道题JS继承题目【面试官再也难不倒你了系列】神奇的arguments笔试题【一天突破一个知识点】45道Promise面试题【面试官再也难不倒你了系列】40道this面试题!面试官再也难不到你了! 点在看的人特别帅/美