ES2017 引入了字符串补全长度的功能。如果某个字符串不够指定长度,会在头部或尾部补全。padStart()用于头部补全,padEnd()用于尾部补全 。
专注于为中小企业提供网站制作、网站设计服务,电脑端+手机端+微信端的三站合一,更高效的管理,为中小企业回民免费做网站提供优质的服务。我们立足成都,凝聚了一批互联网行业人才,有力地推动了近1000家企业的稳健成长,帮助中小企业通过网站建设实现规模扩充和转变。
- 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 方法具有的别名。
但是对于字符串填充方法,没有别名。因此,请勿使用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 之外,都 可以用。
本文转载自微信公众号「 大迁世界」,可以通过以下二维码关注。转载本文请联系****公众号。
【责任编辑:赵宁宁 TEL:(010)68476606】
文章名称:JavaScript字符串中的pad方法!
浏览地址:http://www.csdahua.cn/qtweb/news0/403100.html
网站建设、网络推广公司-快上网,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 快上网