input框输入金额完美交互

交互内容:

输入前显示“0.00”
移入后如果是“0.00”则清空内容
移入后如果是“*.00”则去除后面的“.00”以方便填写
移入后如果是“*.*0”则优化成“*.*”,即去掉最后面的“0”以方便填写
什么都没写移出后又再次填充“0.00”
只能输入数字和小数点
仅能输入一个小数点
仅保留后面两个小数点

 1 <div class="mui-input-row">
 2     <label>金额<span>(元)</span></label>
 3     <input type="tel" class="capital mui-input-clear" value="0.00">
 4 </div>
 5 
 6 <style>
 7 *{
 8     font-family:'microsoft yahei';
 9     height:30px;
10     line-height:30px;
11 }
12 input{
13     width:100px;
14     border-radius:.3em;
15     border:1px solid #ccc;
16     padding-left:.5em;
17     margin-left:.3em;
18 }
19 </style>

 js部分:

 1 /*投资本金仅能输入数字和小数点*/
 2 var precapital;
 3 document.querySelector('.capital').addEventListener('focus', function() {
 4     if (this.value == '0.00') {
 5         this.value = '';
 6     } else {
 7         this.value = this.value.replace(/\.00/, '').replace(/(\.\d)0/,'$1');
 8     }
 9     precapital = this.value;
10 });
11 document.querySelector('.capital').addEventListener('keyup', function() {
12 
13     this.value = this.value.replace(/^[\.]/, '').replace(/[^\d.]/g, '');
14     if (this.value.split(".").length - 1 > 1) {
15         this.value = precapital;
16     }
17     precapital = this.value;
18 });
19 document.querySelector('.capital').addEventListener('blur', function() {
20     this.value = this.value.replace(/[\.]$/, '');
21     this.value = this.value.replace(/(.*)\.([\d]{2})(\d*)/g,'$1.$2');
22     this.value = Number(this.value).toFixed(2);
23     var logNum = this.value.toString();
24     if(logNum.match(/\./g) != null){
25         integerNum = parseInt(logNum).toString().replace(/\d(?=(\d{3})+$)/g,'$&,');
26         decimalNum = '.' + logNum.replace(/(.*)\.(.*)/g,'$2');
27         document.querySelector(".logbox").innerHTML = integerNum+decimalNum;
28     }else{
29         document.querySelector(".logbox").innerHTML = logNum.replace(/\d(?=(\d{3})+$)/g,'$&,');
30     }
31 });

请使用手机"扫一扫"x

转载于:https://www.cnblogs.com/kousuke/p/perfect-input-for-money.html

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值