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

js格式化輸入框內(nèi)金額、銀行卡號

 更新時間:2016年02月01日 09:23:48   作者:耶特先生  
這篇文章主要介紹了js格式化輸入框內(nèi)金額、銀行卡號,采用“keyup”事件處理格式化,每4位數(shù)一組中間空格隔開,如何格式化輸入框內(nèi)金額、銀行卡號,需要了解的朋友可以參考一下

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

頁面代碼:

<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位數(shù)一組中間空格隔開。但是數(shù)據(jù)格式化以后又不利于計算,所以給當(dāng)前元素添加一個屬性“data-oral”,保存未處理的數(shù)字,這樣計算或者要傳遞到后臺可以獲取“data-oral”的值。

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

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

/*
    * 金額每3位數(shù)一組逗號隔開格式化
    * 1.先把非數(shù)字的都替換掉
    * 2.由于IE瀏覽器對于change事件存在兼容問題,改用focus和blur事件代替。
    * */
    $("#moneyNum").on("keyup", formatMN);
 
    $("#moneyNum").on({
      focus: function(){
        $(this).attr("data-fmt",$(this).val()); //將當(dāng)前值存入自定義屬性
      },
      blur: function(){
        var oldVal=$(this).attr("data-fmt"); //獲取原值
        var newVal=$(this).val(); //獲取當(dāng)前值
        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")獲取未格式化的金額
    }

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

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

頁面代碼:

<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();
});

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助。

相關(guān)文章

  • w3c聲明下可運行 兼容性比較好的js對聯(lián)廣告集合

    w3c聲明下可運行 兼容性比較好的js對聯(lián)廣告集合

    最近有美工朋友找我們要兼容性比較好的對聯(lián)廣告代碼,我們給他一個他竟然不能運行,經(jīng)過排查,這是因為現(xiàn)在的廣告也用了一樣代碼,函數(shù)命名重復(fù)。
    2011-07-07
  • 基于小程序請求接口wx.request封裝的類axios請求

    基于小程序請求接口wx.request封裝的類axios請求

    這篇文章主要介紹了基于小程序請求接口wx.request封裝的類axios請求,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-07-07
  • javascript驗證只能輸入數(shù)字和一個小數(shù)點示例

    javascript驗證只能輸入數(shù)字和一個小數(shù)點示例

    使用javascript限制只能輸入數(shù)字和一個小數(shù)點,在某些情況下還是比較使用的,下面有個不錯的示例,感興趣的朋友可以參考下
    2013-10-10
  • 判斷腳本加載是否完成的方法

    判斷腳本加載是否完成的方法

    在“按需加載”的需求中,我們經(jīng)常會判斷當(dāng)腳本加載完成時,返回一個回調(diào)函數(shù),那如何去判斷腳本的加載完成呢?
    2009-05-05
  • ES6擴(kuò)展運算符和rest運算符用法實例分析

    ES6擴(kuò)展運算符和rest運算符用法實例分析

    這篇文章主要介紹了ES6擴(kuò)展運算符和rest運算符用法,結(jié)合實例形式分析了ES6擴(kuò)展運算符和rest運算符基本功能、用法及操作注意事項,需要的朋友可以參考下
    2020-05-05
  • JavaScript繼承與多繼承實例分析

    JavaScript繼承與多繼承實例分析

    這篇文章主要介紹了JavaScript繼承與多繼承,結(jié)合實例形式較為詳細(xì)的分析了JavaScript繼承與多繼承的概念、原理、實現(xiàn)與使用方法,需要的朋友可以參考下
    2018-05-05
  • 微信小程序開發(fā)之大轉(zhuǎn)盤 仿天貓超市抽獎實例

    微信小程序開發(fā)之大轉(zhuǎn)盤 仿天貓超市抽獎實例

    本篇文章主要介紹了微信小程序開發(fā)之大轉(zhuǎn)盤 仿天貓超市抽獎實例,這里整理了詳細(xì)的代碼,具有一定的參考價值,感興趣的小伙伴們可以參考一下。
    2016-12-12
  • js 未結(jié)束的字符串常量錯誤解決方法

    js 未結(jié)束的字符串常量錯誤解決方法

    在編碼js過程中,經(jīng)常遇到未結(jié)束的字符串常量這樣提示的錯誤,做下總結(jié),以方便以后查閱.
    2010-06-06
  • 詳解JavaScript中的this硬綁定

    詳解JavaScript中的this硬綁定

    這篇文章主要為大家詳細(xì)介紹了JavaScript中的this顯示綁定和硬綁定,文中的示例代碼講解詳細(xì),具有一定的借鑒價值,感興趣的可以了解一下
    2022-10-10
  • 微信小程序?qū)崿F(xiàn)定位及到指定位置導(dǎo)航的示例代碼

    微信小程序?qū)崿F(xiàn)定位及到指定位置導(dǎo)航的示例代碼

    這篇文章主要介紹了微信小程序?qū)崿F(xiàn)定位及到指定位置導(dǎo)航的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-08-08

最新評論