作者: Dmitri Pavlutin 译者:前端小智 来源:dmitripavlutin
点赞再看,养成习惯
本文 GitHub https://github.com/qq449245884/xiaozhi 上已经收录,更多往期高赞文章的分类,也整理了很多我的文档,和教程资料。欢迎Star和完善,大家面试可以参照考点复习,希望我们一起有点东西。
ES2017 引入了字符串补全长度的功能。如果某个字符串不够指定长度,会在头部或尾部补全。padStart()用于头部补全,padEnd()用于尾部补全 🎀。
const string = 'hi'; string.padStart(3, 'c'); // "chi" string.padEnd(4, 'l'); // "hill"padEnd和padStart接受相同的参数。
最终字符串的长度。
const result = string.padStart(5); result.length; // 5当我看到这个时,也花了我一段时间来学习。 我一直以为maxLength是重复填充字符串参数的次数。 所以这里只想强调一下此参数是当前字符串需要填充到的目标长度,不是填充字符串重复的次数。如果这个数值小于当前字符串的长度,则返回当前字符串本身。
当然,我相信读者比我聪明多了,所以我确定你没有这种困惑 😆
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 转成一个字符串,得到一个TypeError:
undefined.toString(); // TypeError: Cannot read property 'toString' of undefined但当我们把undefined作为第二个参数传入padStart,会得到这个:
'SAM'.padStart(10, undefined); // ' SAM'所以上面说的 padString 参数会使用 toString 强制转成字符串使用,到这里感觉又不对了 🙊。我们先来看下规范:
ECMAScript 规范 :如果填充的字符串是 undefined,该填充的字符串就会被规制成空格( 0x0020)。
好吧,我们更正一下, 除了undefined,否则传递的所有其他数据类型都将使用toString强制转成字符串。
如果 maxLength 数值小于等于当前字符串的长度,则返回当前字符串本身。
'hi'.padEnd(2, 'SAM'); // 'hi'如果 maxLength 小于 padString 的长度,则 padString 会被截断。
'hi'.padEnd(7, 'SAMANTHA'); // 'hiSAMAN'trim 方法具有的别名。
trimLeft是trimStart的别名
trimRight 是 trimStart的别名
但是对于字符串填充方法,没有别名。 因此,请勿使用padLeft和padRight,它们不存在。 这也是建议你不要使用trim别名的原因,这样让代码库中具有一致性 😄
得到的结果
JavaScript HTML CSS VuepadStart和padEnd是同时引入的,因此它们共享相似的浏览器支持, 除了 IE 之外,都 可以用 😅
原文:https://dmitripavlutin.com/replace-all-string-occurrences-javascript/
代码部署后可能存在的BUG没法实时知道,事后为了解决这些BUG,花了大量的时间进行log 调试,这边顺便给大家推荐一个好用的BUG监控工具 Fundebug。
干货系列文章汇总如下,觉得不错点个Star,欢迎 加群 互相学习。
https://github.com/qq449245884/xiaozhi
我是小智,公众号「大迁世界」作者,对前端技术保持学习爱好者。我会经常分享自己所学所看的干货,在进阶的路上,共勉!
关注公众号,后台回复福利,即可看到福利,你懂的。
前端小智@大迁世界 认证博客专家 TypeScript ECMAScript 6 前端框架 我不是什么大牛,我其实想做的就是一个传播者。内容可能过于基础,但对于刚入门的人来说或许是一个窗口,一个解惑之窗。我要先坚持分享20年,大家来一起见证吧。