本篇內(nèi)容介紹了“js自動補位擴展padLeft、padRight的方法”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!
九龍坡網(wǎng)站建設公司創(chuàng)新互聯(lián)公司,九龍坡網(wǎng)站設計制作,有大型網(wǎng)站制作公司豐富經(jīng)驗。已為九龍坡數(shù)千家提供企業(yè)網(wǎng)站建設服務。企業(yè)網(wǎng)站搭建\外貿(mào)營銷網(wǎng)站建設要多少錢,請找那個售后服務好的九龍坡做網(wǎng)站的公司定做!JS是JavaScript的簡稱,它是一種直譯式的腳本語言,其解釋器被稱為JavaScript引擎,是瀏覽器的一部分,主要用于web的開發(fā),可以給網(wǎng)站添加各種各樣的動態(tài)效果,讓網(wǎng)頁更加美觀。
方法一、自定義函數(shù)實現(xiàn),不方便自定義調用
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對象,導致對象回收慢)
類似
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.降低時間復雜度
“js自動補位擴展padLeft、padRight的方法”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關的知識可以關注創(chuàng)新互聯(lián)成都網(wǎng)站設計公司網(wǎng)站,小編將為大家輸出更多高質量的實用文章!
另外有需要云服務器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務器、裸金屬服務器、高防服務器、香港服務器、美國服務器、虛擬主機、免備案服務器”等云主機租用服務以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應用場景需求。
分享文章:js自動補位擴展padLeft、padRight的方法-創(chuàng)新互聯(lián)
文章源于:http://jinyejixie.com/article36/dsicsg.html
成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站制作、網(wǎng)頁設計公司、移動網(wǎng)站建設、定制網(wǎng)站、云服務器、域名注冊
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉載內(nèi)容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)