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

const string = 'hi';

string.padStart(3, 'c'); // "chi"

string.padEnd(4, 'l'); // "hill"

语法

string.padStart(, )string.padEnd(, )

了解参数

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'

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

  • trimLefttrimStart的别名

  • trimRighttrimStart的别名

但是对于字符串填充方法,没有别名。因此,请勿使用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 之外,都 可以用 ?


作者: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面试题!面试官再也难不到你了!

点在看的人特别帅/美

mybatis字符串转成数字_JavaScript 字符串中的 pad 方法!相关推荐

  1. html把字符串转换成数字,js字符串转换成数字的三种方法

    在js读取文本框或者其它表单数据的时候获得的值是字符串类型的,例如两个文本框a和b,如果获得a的value值为11,b的value值为9 ,那么a.value要小于b.value,因为他们都是字符串形 ...

  2. mybatis字符串转成数字_Python字符串三种格式化输出

    字符串格式化输出是python非常重要的基础语法,今天就把三种格式化输出做一个简单的总结,希望对大家有帮助. 格式化输出:内容按照一定格式要求进行输出. 1.使用占位符%输出 python2.6版本之 ...

  3. js 转化为实体符_js字符串转换成数字与数字转换成字符串的实现方法

    本篇文章主要是对js字符串转换成数字与数字转换成字符串的实现方法进行了详细的介绍,需要的朋友可以过来参考下,希望对大家有所帮助 js字符串转换成数字 将字符串转换成数字,得用到parseInt函数. ...

  4. java大数转换成字符串,js字符串转换成数字与数字转换成字符串的实现方法

    摘要:这篇JavaScript栏目下的"js字符串转换成数字与数字转换成字符串的实现方法",介绍的技术点是"js字符串.字符串转换.实现方法.数字转换.字符串.转换&qu ...

  5. 字符串转换成数字的方法【C#】

    在C#中,经常需要将字符串转换成数字,简单总结三种方法: 一.Convert:将一个基本数据类型转换成另一个基本数据类型. 比如,将用户输入的数学成绩进行转换: int math = Convert. ...

  6. LeetCode 28. 找出字符串中第一个匹配项的下标 -- 字符串编码成数字匹配

    找出字符串中第一个匹配项的下标 中等 1.6K 相关企业 给你两个字符串 haystack 和 needle ,请你在 haystack 字符串中找出 needle 字符串的第一个匹配项的下标(下标从 ...

  7. python中字符串转成数字的几种方法

    在python列表操作中,面对需要把列表中的字符串转为礼拜的操作,无需强转,通过简单的几步就可以实现,本文介绍python中字符串转成数字的三种方法:1.使用join的方法:2.使用int函数将16进 ...

  8. c语言中输入字符转换成整数,c语言数字字符串转换成整数 C语言中如何将数字变成字符串啊?...

    C语言:把数字字符串转换成整型数字不懂时,别乱说:懂得时,别多说:心乱时,慢慢说:没话时,就别说. 运行环境:TC2. 把数字字符串转换成整型数字.比如说小编输入一个数字字符当你年轻时,你以为什么都有 ...

  9. python中列表中的字符串转换成数字

    python中列表中的字符串转换成数字 调整实验时,发现某个嵌套列表的字典中需要把列表中的字符串改成数字,不能直接强转,需要以下代码实现 m_dict_G = {}for key in md_dict ...

  10. js 字符串转换成数字的 三种方法

    在js读取文本框或者其它表单数据的时候获得的值是字符串类型的,例如两个文本框a和b,如果获得a的value值为11,b的value值为9 ,那么a.value要小于b.value,因为他们都是字符串形 ...

最新文章

  1. c++语言中如何写入文件,C++:在多线程程序中写入文件
  2. 为什么说新型冠状病毒疫苗会研制成功?
  3. java小知识_java小知识点简单回顾
  4. go 连接服务器 并存放图片_基于 Go 语言开发在线论坛(二):通过模型类与MySQL数据库交互...
  5. 2016年社招面试小结
  6. Atitit es6新特性 Es7 es8 新特性 目录 1.1. ECMAScript 的历史 1 2. 新特性 2 2.1. 全面的class模型 2 2.2. .模块 import、expor
  7. 恒生Pb系统与讯投PB系统、PTrade交易系统比较
  8. 转载:真正高人的解读——《三体 读后感》【宇宙尺度的战争】
  9. 机械设计基础课程设计【1】
  10. SEM和SEO的区别
  11. ❤️粉丝专属福利❤️
  12. python opencv imshow可以显示,但是imwrite却黑乎乎
  13. 你好,你是谁,可不可以向我出示源代码让我确认身份
  14. SQL联合查询 join
  15. 让2010成为我的新纪元
  16. Neo4j数据库知识图谱查询关联人物关系和cypher查询
  17. c语言 设置windows2008,调教Windows server 2008系统菜单
  18. 别人的随笔(非常有用)
  19. 永中word页码怎么从第二页开始_江苏印刷网:Word操作技巧,解决打印难题
  20. 【产业互联网周报】北京三年内建300平方公里自动驾驶示范区;首条5G车联网示范路提效20%;信通院车联网创新中心正式成立...

热门文章

  1. Atitit 大数据索引技术attilax总结 目录 1. 面临的问题 2 1.1. 找到太多数据 2 1.2. 不支持多字段搜索 2 1.3. 不支持模糊搜索 2 1.4. 聚合搜索 2 1.5
  2. Atitit 全文检索 pgsql 艾提拉总结 分词 全文索引的实现要靠 PgSQL 的 gin 索引。分词功能 PgSQL 内置了英文、西班牙文等,但中文分词需要借助开源插件 zhparser;
  3. Atitit 如何工作积极的心态积极起来
  4. paip.提高效率---集合的存取括号方式 uapi java python php js 的实现比较
  5. 软件网站安全性的设计与检测与解决方案
  6. 当Java遇上机密计算
  7. 如何做一个有品位的程序员
  8. 央行DECP开测,拉开全球货币霸权之战大幕 | 凌云时刻
  9. 7纳米,80核:Ampere第二代云数据中心Arm芯片即将推出
  10. 11月20日取消纸质车票,怎么报销