中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

jQuery如何實現金額錄入框

發布時間:2021-06-25 09:49:48 來源:億速云 閱讀:134 作者:小新 欄目:開發技術

這篇文章主要介紹了jQuery如何實現金額錄入框,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

前端開發過程中,通常會用到數值錄入框,比如要求輸入金額,禁止錄入非數值字符,也禁止粘貼非數值字符,怎么實現呢?

首先通過(function($){  })(jQuery); 即時執行函數用于模塊隔離,可以避免與其他功能模塊、插件之間產生變量污染問題,所有私有的全局變量可以放在即時執行函數的頭部。

然后在jquery原型上擴展numbox方法

(function ($) {
 // 數值輸入框
 $.fn.numbox = function (options) {
 var type = (typeof options);
 if (type == 'object') {
       // 創建numbox對象
  if (options.width) this.width(options.width);
  if (options.height) this.height(options.height);
  this.bind("input propertychange", function (obj) {
  numbox_propertychange(obj.target);
  });
  this.bind("change", function (obj) {
  var onChange = options.onChange;
  if (!onChange) return;
  var numValue = Number(obj.target.value);
  onChange(numValue);
  });
  this.bind("hide", function (obj) {
  var onHide = options.onHide;
  if (!onHide) return;
  var numValue = Number(obj.target.value);
  onHide(numValue);
  });
  return this;
 }
 else if (type == 'string') {
       // type為字符串類型,代表調用numbox對象中的方法
  var method = eval(options);
  if (method) return method(this, arguments);
 }
 }
 // 屬性值變化事件
 function numbox_propertychange(numbox) {
 if (numbox.value == '-' || numbox.value == numbox.oldvalue) return;
 var numvalue = Number(numbox.value);
 if (isNaN(numvalue)) {
  numbox.value = numbox.oldvalue;
 }
 else {
  numbox.oldvalue = numbox.value;
 }
 }
 // 獲取值
 function getValue(numbox) {
 var value = numbox.val();
 return Number(value);
 }
 // 設置值
 function setValue(numbox, params) {
 if (params[1] == undefined) return;
 var numvalue = Number(params[1]);
 if (!isNaN(numvalue)) {
  for (var i = 0; i < numbox.length; i++) {
  numbox[i].focus();
  numbox[i].value = numvalue;
  numbox[i].oldvalue = numvalue;
  }
 }
 }
})(jQuery); // 這里傳入jQuery對象作為參數,是為了避免在模塊內部直接去訪問全局對象,避免過度依賴其他模塊,降低耦合度,更加規范化,可控性更高,可參考其他成熟jQuery插件(easyui、bootstrap)

調用方法如下

<body>
 <input id="test" />
 <script>
 $("#test").numbox({
  width: 150,
  height: 20
 });
 </script>
</body>

感謝你能夠認真閱讀完這篇文章,希望小編分享的“jQuery如何實現金額錄入框”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關注億速云行業資訊頻道,更多相關知識等著你來學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

宁陵县| 梅州市| 南城县| 静海县| 阿巴嘎旗| 福清市| 饶阳县| 日土县| 周口市| 格尔木市| 哈巴河县| 义马市| 朔州市| 红安县| 隆化县| 东海县| 荔浦县| 吉隆县| 岐山县| 景谷| 贡山| 黎城县| 奈曼旗| 盘锦市| 平原县| 沭阳县| 盐城市| 娄烦县| 万全县| 房产| 德阳市| 灵宝市| 鄂尔多斯市| 依兰县| 永登县| 河北省| 天全县| 伊春市| 博乐市| 化州市| 博湖县|