国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

js格式化輸入框內金額、銀行卡號

2019-11-20 10:39:14
字體:
來源:轉載
供稿:網友

我們在項目中經常遇到需要格式化的金額數和銀行卡號,一般我們常見的有兩種表現形式:輸入框內格式化和輸入框外格式化。這里我主要把我在項目中遇到的輸入框內部格式化的,代碼亮出來,框外的格式化相對簡單一點。

頁面代碼:

<div class="wrap">  <input type="text" id="bankCard" placeholder="輸入銀行卡號"></div> <div class="wrap">  <input type="text" id="moneyNum" placeholder="輸入金額"></div>

 銀行卡號格式化

//卡號每4位一組格式化    $("#bankCard").on("keyup", formatBC);     function formatBC(e){       $(this).attr("data-oral", $(this).val().replace(// +/g,""));      //$("#bankCard").attr("data-oral")獲取未格式化的卡號       var self = $.trim(e.target.value);      var temp = this.value.replace(//D/g, '').replace(/(....)(?=.)/g, '$1 ');      if(self.length > 22){        this.value = self.substr(0, 22);        return this.value;      }      if(temp != this.value){        this.value = temp;      }    } 

這里用“keyup”事件處理格式化,每4位數一組中間空格隔開。但是數據格式化以后又不利于計算,所以給當前元素添加一個屬性“data-oral”,保存未處理的數字,這樣計算或者要傳遞到后臺可以獲取“data-oral”的值。

金額格式化
金額格式化和銀行卡號格式化類似,但又有點不同,因為金額每3位數一組用逗號隔開,一般最后有小數點且保留兩位有效數字。這里我開始用到“keyup”和"change"事件,但是IE瀏覽器對于change事件存在兼容問題,可以改用focus和blur事件代替

類似給元素添加屬性“data-oral”保存未格式化的數字。

/*    * 金額每3位數一組逗號隔開格式化    * 1.先把非數字的都替換掉    * 2.由于IE瀏覽器對于change事件存在兼容問題,改用focus和blur事件代替。    * */    $("#moneyNum").on("keyup", formatMN);     $("#moneyNum").on({      focus: function(){        $(this).attr("data-fmt",$(this).val()); //將當前值存入自定義屬性      },      blur: function(){        var oldVal=$(this).attr("data-fmt"); //獲取原值        var newVal=$(this).val(); //獲取當前值        if (oldVal!=newVal) {          if(newVal == "" || isNaN(newVal)){            this.value = "";            return this.value;          }          var s = this.value;          var temp;           if(/.+(/..*/.|/-).*/.test(s)){            return;          }          s = parseFloat((s + "").replace(/[^/d/./-]/g, "")).toFixed(2) + "";          var l = s.split(".")[0].split("").reverse(),              r = s.split(".")[1];          t = "";          for(i = 0; i < l.length; i ++ ) {            t += l[i] + ((i + 1) % 3 == 0 && (i + 1) != l.length && (l[i+1]!='-')? "," : "");          }          temp = t.split("").reverse().join("") + "." + r;          this.value = temp;          return this.value;        }      }    });     function formatMN(e){      this.value = this.value.replace(/[^/d/./-]/g,"");      $(this).attr("data-oral", parseFloat(e.target.value.replace(/[^/d/.-]/g, "")));      //$("#moneyNum").attr("data-oral")獲取未格式化的金額    }

其實我覺得,輸入框外的格式化更合理一些,大多數都是輸入框外部格式化的,我寫了個例子也拉出來吧。

輸入框外部格式化卡號
原理很簡單,就是隱藏一個顯示格式化的模塊,當輸入框獲取焦點時顯示,失去焦點時隱藏即可。

頁面代碼:

<div class="inputCard-wrap">  <input type="text" class="inputCard">  <div class="panelCard"></div></div> <style type="text/css">  .inputCard-wrap{    position: relative;  }  .inputCard-wrap .panelCard{    display: none;    position: absolute;    top:-34px;    left:0;    z-index: 100;    background-color:#fff9da;    border:1px #ffce6e solid;    padding:10px;    height:40px;    font-size: 1.7em;    line-height:18px;    color:#585858;  }</style>

格式化代碼:

/* 銀行卡號實時驗證放大顯示 */$(".inputCard").keyup(function(e){  var self = $.trim(e.target.value),    parent = $(e.target).closest(".inputCard-wrap"),    panel = $(".panelCard", parent),    val = self.replace(//D/g, '');  if(self.length > 18){    this.value = self.substr(0, 18);    return this.value;  }  if(val == self){    panel.show();    val = self.replace(/(....)(?=.)/g, '$1 ');    panel.html(val);  }else{    panel.hide();    return self;  }});$(".inputCard").unbind('focusin');$(".inputCard").bind('focusin',function(e){  var self = $.trim(e.target.value),    parent = $(e.target).closest(".inputCard-wrap"),    panel = $(".panelCard", parent),    val = self.replace(/(....)(?=.)/g, '$1 ');  if(val != '') {    panel.show();    panel.html(val);  }});$(".inputCard").unbind('focusout');$(".inputCard").bind('focusout',function(e){  var parent = $(e.target).closest(".inputCard-wrap"),    panel = $(".panelCard", parent);  panel.hide();});

以上就是本文的全部內容,希望對大家的學習有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 克什克腾旗| 上虞市| 兴文县| 保靖县| 昭觉县| 藁城市| 芜湖县| 曲阜市| 绥芬河市| 六盘水市| 旺苍县| 鹤峰县| 海晏县| 台南县| 尼勒克县| 尚志市| 神池县| 乌鲁木齐县| 湘潭市| 宜章县| 武宣县| 镇江市| 长沙市| 墨玉县| 泰顺县| 苗栗市| 临朐县| 淅川县| 大荔县| 高碑店市| 北辰区| 玛沁县| 巫溪县| 广平县| 黔东| 通山县| 包头市| 如皋市| 福安市| 五莲县| 会理县|