欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

js中位數(shù)不足自動補位擴展padLeft、padRight實現(xiàn)代碼

 更新時間:2020年04月06日 23:06:00   作者:Jack丶Chen  
這篇文章主要介紹了js中位數(shù)不足自動補位擴展之padLeft、padRight實現(xiàn)方法,主要是通過String.prototype擴展實現(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)文章

  • 如何用CocosCreator制作微信小游戲

    如何用CocosCreator制作微信小游戲

    這篇文章主要介紹了如何用CocosCreator制作微信小游戲,從下載工具到配置,最后連接微信小游戲預(yù)覽,一步步很詳細,希望讀者們仔細看一下
    2021-04-04
  • JavaScript生成隨機驗證碼代碼實例

    JavaScript生成隨機驗證碼代碼實例

    這篇文章主要介紹了JavaScript生成隨機驗證碼代碼實例,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習或者工作具有一定的參考學(xué)習價值,需要的朋友可以參考下
    2019-09-09
  • 微信JS接口大全

    微信JS接口大全

    這篇文章主要為大家分享了最全面詳細的微信JS接口大全,希望對大家有幫助,感興趣的小伙伴們可以參考一下
    2016-08-08
  • 小議javascript 設(shè)計模式 推薦

    小議javascript 設(shè)計模式 推薦

    最近重新溫習了一次《javascript設(shè)計模式》,確實是一本好書,每次看都有不同的領(lǐng)悟,每次領(lǐng)悟到的都受益匪淺,無怪古圣人都說學(xué)無止鏡了,僅以“加油,好嗎?”共勉!
    2009-10-10
  • JavaScript中變量提升導(dǎo)致未定義(undefined)的問題及解決方法

    JavaScript中變量提升導(dǎo)致未定義(undefined)的問題及解決方法

    在 JavaScript 中,變量提升(Hoisting)是一個相對常見的行為,尤其是當你遇到 undefined 錯誤時,本文將詳細探討變量提升的概念、其對代碼執(zhí)行的影響以及如何避免因為變量提升而導(dǎo)致 undefined 的問題,需要的朋友可以參考下
    2024-09-09
  • js實現(xiàn)瀏覽器窗口大小被改變時觸發(fā)事件的方法

    js實現(xiàn)瀏覽器窗口大小被改變時觸發(fā)事件的方法

    這篇文章主要介紹了js實現(xiàn)瀏覽器窗口大小被改變時觸發(fā)事件的方法,實例分析了window.onresize方法的使用技巧,需要的朋友可以參考下
    2015-02-02
  • javaScript中封裝的各種寫法示例(推薦)

    javaScript中封裝的各種寫法示例(推薦)

    這篇文章主要給大家介紹了關(guān)于javaScript中封裝的各種寫法的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家具有一定的參考學(xué)習價值,需要的朋友們下面來一起看看吧。
    2017-07-07
  • javascript 閉包

    javascript 閉包

    閉包是一個擁有許多變量和綁定了這些變量的環(huán)境的表達式(通常是一個函數(shù)),因而這些變量也是該表達式的一部分,本文將用通俗的語言帶您深入理解Javascript閉包的概念。
    2011-09-09
  • JS實現(xiàn)在線統(tǒng)計一個頁面內(nèi)鼠標點擊次數(shù)的方法

    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)頁手機音樂播放器 歌詞同步播放的示例

    下面小編就為大家分享一篇原生JS實現(xiàn)網(wǎng)頁手機音樂播放器 歌詞同步播放的示例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-02-02

最新評論