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-09js實現(xiàn)瀏覽器窗口大小被改變時觸發(fā)事件的方法
這篇文章主要介紹了js實現(xiàn)瀏覽器窗口大小被改變時觸發(fā)事件的方法,實例分析了window.onresize方法的使用技巧,需要的朋友可以參考下2015-02-02JS實現(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