js中位數(shù)不足自動補位擴展padLeft、padRight實現(xiàn)代碼
方法一、自定義函數(shù)實現(xiàn),不方便自定義調(diào)用
function FillZero(p) {
return new Array(3 - (p + '').length + 1).join('0') + p;
}
FillZero(6); //輸出006
方法二、String方法一擴展(C#中PadLeft、PadRight)
String.prototype.PadLeft = function (len, charStr) {
var s = this + '';
return new Array(len - s.length + 1).join(charStr || '') + s;
}
String.prototype.PadRight = function (len, charStr) {
var s = this + '';
return s + new Array(len - s.length + 1).join(charStr || '');
}
var p = 6;
p.toString().PadLeft(3, '0'); //輸出006
p.toString().PadRight(3, '0'); //輸出600
方法三、原理同方法二
<script type="text/javascript">
String.prototype.pad= function (pos,len,padStr) {
var padStrs = new Array(len).join(padStr,'');
return pos ? (padStrs + this.toString()).substr(0-len):(this.toString() + padStrs).substr(0,len);
}
String.prototype.lpad = function(len,padStr){
return this.pad(1,len,padStr);
}
String.prototype.rpad = function(len,padStr){
return this.pad(0,len,padStr);
}
String.prototype.padLeft = String.prototype.lpad;
String.prototype.padRight = String.prototype.rpad;
var str="6";
console.log(str.lpad(2,"0"));
console.log(str.padLeft(2,"0"));
</script>
代碼四、
String.prototype.padLeft = function (padChar, width) {
var ret = this;
while (ret.length < width) {
if (ret.length + padChar.length < width) {
ret = padChar + ret;
}
else {
ret = padChar.substring(0, width - ret.length) + ret;
}
}
return ret;
};
String.prototype.padRight = function (padChar, width) {
var ret = this;
while (ret.length < width) {
if (ret.length + padChar.length < width) {
ret += padChar;
}
else {
ret += padChar.substring(0, width - ret.length);
}
}
return ret;
};
下面是其他網(wǎng)友的補充
javascript-leftpad方法
原由是微博上出的一則leftpad方法被吐槽的事。
原方法是通過循環(huán)挨個拼接字符串的方式,所以效率差了點(會產(chǎn)生N多string對象,導(dǎo)致對象回收慢)
類似
for(i=0;i<cnt;i++){
str=pad+str;
}
改進如下:
//cache
var padding1="00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000";
var padding2=" ";
function leftpad(str,length,useSpace){
var padding = padding1;
if(useSpace){
padding = padding2;
}
var cnt = length-str.length;
if(cnt<=0) return str;
if(cnt<=200) return padding.substring(0,cnt)+str;
str=padding+str;
return leftpad(str,length,ch);
}
思路:
1.減少string對象的生成,所以盡量減少字符串拼接的次數(shù)
2.降低時間復(fù)雜度
以上就是js中位數(shù)不足自動補位擴展padLeft、padRight實現(xiàn)代碼的詳細內(nèi)容,更多關(guān)于js自動補位 padLeft、padRight的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
JavaScript中變量提升導(dǎo)致未定義(undefined)的問題及解決方法
在 JavaScript 中,變量提升(Hoisting)是一個相對常見的行為,尤其是當你遇到 undefined 錯誤時,本文將詳細探討變量提升的概念、其對代碼執(zhí)行的影響以及如何避免因為變量提升而導(dǎo)致 undefined 的問題,需要的朋友可以參考下2024-09-09
js實現(xiàn)瀏覽器窗口大小被改變時觸發(fā)事件的方法
這篇文章主要介紹了js實現(xiàn)瀏覽器窗口大小被改變時觸發(fā)事件的方法,實例分析了window.onresize方法的使用技巧,需要的朋友可以參考下2015-02-02
JS實現(xiàn)在線統(tǒng)計一個頁面內(nèi)鼠標點擊次數(shù)的方法
這篇文章主要介紹了JS實現(xiàn)在線統(tǒng)計一個頁面內(nèi)鼠標點擊次數(shù)的方法,實例分析了javascript操作Cookie實現(xiàn)計數(shù)的技巧,需要的朋友可以參考下2015-02-02
原生JS實現(xiàn)網(wǎng)頁手機音樂播放器 歌詞同步播放的示例
下面小編就為大家分享一篇原生JS實現(xiàn)網(wǎng)頁手機音樂播放器 歌詞同步播放的示例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-02-02

