java padend_JS字符串补全方法padStart()和padEnd()

这个方法无意中看到的,感觉还是蛮实用的,特此分享一波。我想大家都会有遇到将时间戳转换成时间格式的时候,时间或日期不足2位的前面补0。有了今天说的这个东西,就又可以少写几行代码了,大家在项目中遇到类似场景可以去使用感受下。

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

padStart() padEnd() 方法用另一个字符串填充当前字符串(如果需要的话则重复填充),返回填充后达到指定长度的字符串。

padStart() 从当前字符串的开始(左侧) 位置填充。

padEnd() 从当前字符串的末尾(右侧)开始填充。

语法:

str.padStart(targetLength [, padString])

str.padEnd(targetLength [, padString])

padStart() 和 padEnd() 一共接受两个参数,第一个参数 targetLength 是当前字符串需要填充到的目标长度,第二个参数 padString 是用来填充的字符串,缺省值为" "。

返回值:

在原字符串开头填充指定的填充字符串直到目标长度所形成的新字符串。

如果 targetLength 小于当前字符串的长度,则字符串补全不生效,返回当前字符串本身。

'abc'.padStart(1, 'd'); // "abc"

'abc'.padEnd(1, 'd'); // "abc"

如果 targetLength 小于用来填充的字符串长度与原字符串的长度之和,则截掉超出位数的补全字符串。

'abc'.padStart(6,"123456"); // "123abc"

'abc'.padEnd(6, "123456"); // "abc123"

如果省略第二个参数 padString,即使用空格补全长度。

'abc'.padStart(10); // " abc"

'abc'.padEnd(10); // "abc "

如果 padString 长度过长,则会删除后面多出的字符串。

'abc'.padStart(5, "foo"); // "foabc"

'abc'.padEnd(5, "foo"); // "abcfo"

应用:

补全指定位数,如格式化时间或日期时,个位数补0

提示字符串格式 字符串拼接

示例:

当我们使用时间戳并转换成 yyyy-mm-dd hh:mm:ss 的格式。

function dataFormat(data) {

const dt = new Date(data * 1000) //注:如果是13位时间戳不用*1000

const y = dt.getFullYear()

const m = (dt.getMonth() + 1 + '').padStart(2, '0')

const d = (dt.getDay() + '').padStart(2, '0')

const hh = (dt.getHours() + '').padStart(2, '0')

const mm = (dt.getMinutes() + '').padStart(2, '0')

const ss = (dt.getSeconds() + '').padStart(2, '0')

return `${y}-${m}-${d} ${hh}:${mm}:${ss}`

}

因着此方法是ES6新增方法,部分浏览器不支持,会有兼容性问题。 查看 Polyfill创建的String.prototype.padStart() / String.prototype.padEnd() 方法。

// https://github.com/uxitten/polyfill/blob/master/string.polyfill.js

// https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/padEnd

if (!String.prototype.padEnd) {

String.prototype.padEnd = function padEnd(targetLength,padString) {

targetLength = targetLength>>0; //floor if number or convert non-number to 0;

padString = String((typeof padString !== 'undefined' ? padString: ''));

if (this.length > targetLength) {

return String(this);

}

else {

targetLength = targetLength-this.length;

if (targetLength > padString.length) {

padString += padString.repeat(targetLength/padString.length); //append to original to ensure we are longer than needed

}

return String(this) + padString.slice(0,targetLength);

}

};

}

到此这篇关于JS字符串补全方法padStart()和padEnd()的文章就介绍到这了,更多相关JS padStart() padEnd()内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值