• 技术文章 >web前端 >js教程

    详解JavaScript中的padStart()和padEnd()方法

    青灯夜游青灯夜游2020-12-09 18:01:36原创2097

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

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

    语法

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

    了解参数

    padEndpadStart接受相同的参数。

    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]'

    有了这些知识,我们看看是否可以将这些其他值类型传递给padStartpadEnd具有相同的行为)。

    '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 方法具有的别名。

    但是对于字符串填充方法,没有别名。 因此,请勿使用padLeftpadRight,它们不存在。 这也是建议你不要使用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

    浏览器支持

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

    原文地址:https://dmitripavlutin.com/replace-all-string-occurrences-javascript/

    作者: Dmitri Pavlutin

    译文地址:https://segmentfault.com/a/1190000023721944

    更多编程相关知识,请访问:编程入门!!

    以上就是详解JavaScript中的padStart()和padEnd()方法的详细内容,更多请关注php中文网其它相关文章!

    声明:本文原创发布php中文网,转载请注明出处,感谢您的尊重!如有疑问,请联系admin@php.cn处理
    上一篇:nodejs怎么实现对图片进行批量裁剪? 下一篇:详解CSS和JS动画底层原理及如何优化它们的性能
    大前端线上培训班

    相关文章推荐

    • JavaScript中var、let和const之间有什么区别?• javascript原型和继承是面试必会的• 详解JavaScript的空值合并运算符(??)• JavaScript Web Workers的构建块及5个使用场景• 12个编写干净且可扩展的JavaScript代码的小技巧

    全部评论我要评论

  • 取消发布评论发送
  • 1/1

    PHP中文网