领先的免费Web技术教程,涵盖HTML到ASP.NET

网站首页 > 知识剖析 正文

(亲测可用)input只能输入数字或小数点后几位

nixiaole 2025-02-13 13:36:17 知识剖析 13 ℃

webapp是基于html5网页版的app,经常会结合app成为混合模式 hybrid app,也就是 app小应用打开 访问的其实是网页,这种方式非常不错,解决了app更新的难题, 所以这个时候要求 webapp需要做的非常像原生app一样。

下面是切图网(qietu.com)在实际项目中碰到一个问题,关于 input 只能输入数字和小数点后俩位的验证。下面js代码亲测有效,目前已在项目中使用。

  1. //jquery控制只输入数字或小数点后几位

  2. $(function(){

  3. // JavaScript Document

  4. $.fn.decimalinput = function(num) {

  5. $(this).css("ime-mode", "disabled");

  6. this.bind("keypress", function(e) {

  7. if (e.charCode === 0) return true; //非字符键 for firefox

  8. var code = (e.keyCode ? e.keyCode : e.which); //兼容火狐 IE

  9. if (code >= 48 && code <= 57) {

  10. var pos = getCurPosition(this);

  11. var selText = getSelectedText(this);

  12. var dotPos = this.value.indexOf(".");

  13. if (dotPos > 0 && pos > dotPos) {

  14. if (pos > dotPos + 2) return false;

  15. if (selText.length > 0 || this.value.substr(dotPos + 1).length < num)

  16. return true;

  17. else

  18. return false;

  19. }

  20. return true;

  21. }

  22. //输入"."

  23. if (code == 46) {

  24. var selText = getSelectedText(this);

  25. if (selText.indexOf(".") > 0) return true; //选中文本包含"."

  26. else if (/^[0-9]+\.$/.test(this.value + String.fromCharCode(code)))

  27. return true;

  28. }

  29. return false;

  30. });

  31. this.bind("blur", function() {

  32. if (this.value.lastIndexOf(".") == (this.value.length - 1)) {

  33. this.value = this.value.substr(0, this.value.length - 1);

  34. } else if (isNaN(this.value)) {

  35. this.value = "";

  36. }

  37. if (this.value)

  38. this.value = parseFloat(this.value).toFixed(2);

  39. $(this).trigger("input");

  40. });

  41. this.bind("paste", function() {

  42. if (window.clipboardData) {

  43. var s = clipboardData.getData('text');

  44. if (!isNaN(s)) {

  45. value = parseFloat(s);

  46. return true;

  47. }

  48. }

  49. return false;

  50. });

  51. this.bind("dragenter", function() {

  52. return false;

  53. });

  54. this.bind("keyup", function() {

  55. });

  56. this.bind("propertychange", function(e) {

  57. if (isNaN(this.value))

  58. this.value = this.value.replace(/[^0-9\.]/g, "");

  59. });

  60. this.bind("input", function(e) {

  61. if (isNaN(this.value))

  62. this.value = this.value.replace(/[^0-9\.]/g, "");

  63. });

  64. };

  65. //获取当前光标在文本框的位置

  66. function getCurPosition(domObj) {

  67. var position = 0;

  68. if (domObj.selectionStart || domObj.selectionStart == '0') {

  69. position = domObj.selectionStart;

  70. }

  71. else if (document.selection) { //for IE

  72. domObj.focus();

  73. var currentRange = document.selection.createRange();

  74. var workRange = currentRange.duplicate();

  75. domObj.select();

  76. var allRange = document.selection.createRange();

  77. while (workRange.compareEndPoints("StartToStart", allRange) > 0) {

  78. workRange.moveStart("character", -1);

  79. position++;

  80. }

  81. currentRange.select();

  82. }

  83. return position;

  84. }

  85. //获取当前文本框选中的文本

  86. function getSelectedText(domObj) {

  87. if (domObj.selectionStart || domObj.selectionStart == '0') {

  88. return domObj.value.substring(domObj.selectionStart, domObj.selectionEnd);

  89. }

  90. else if (document.selection) { //for IE

  91. domObj.focus();

  92. var sel = document.selection.createRange();

  93. return sel.text;

  94. }

  95. else return '';

  96. }

  97. //$('#fe3').decimalinput(2);

  98. })

关于html5原生配合

一个是 type=number (原生h5自带)

控制手机端默认弹出 数字输入键盘

一个是 step=0.01 (原生 h5 自带)

控制输入框的数字跨度,0.01 代表可以输入 数字和小数点后俩位

切图社区(qietu.cn)原创。

最近发表
标签列表