1

问题

业务开发中经常遇到要弹出数字键盘的问题,产品方希望弹出带小数点的纯数字键盘。
下面代码:

<input type='number'/>

在android下能弹出数字与小数点的键盘,而且自动会屏蔽非法字符,很完美。
但iOS下不是纯数字键盘,只是键盘的第一行是数字而已:
image.png

而且iOS下无法防止中文、字母、空格、及各种特殊符号。而且输入这些符号后绑定的值变成空,无法获取当前显示的内容。

这种键盘很难处理,在keydown input等事件里做输入拦截、过滤,难以处理所有状况。特别是切换到九宫格键盘后更是没法处理。

预期结果

我们想要这样的键盘:
image.png

这种键盘在很多app内部,以及一些组件库里都见到过。iOS原生很容易实现这种数字键盘,h5里比较麻烦。

解决方案如下:

这是一段vue代码:

<input v-model="purchaseMoney" type="text" inputmode="decimal" maxlength="12" placeholder="不少于0.01元" @input="onInputAmount($event)" @blur="onInputBlur($event)">

利用inputmode这个属性,详细请参考:https://developer.mozilla.org...

好,现在键盘已经是带小数点的数字键盘了。在iOS下safari,微信等大概看了下,目前都可以。

键盘是出来了,然后还需要写点逻辑处理一些非法情况:防止复制粘贴进来特殊字符、屏蔽表情、多个小数点并存、开头有多个0、替换开头的0为新的数字、控制小数为2位等。

onInputAmount() {
  let temp = this.purchaseMoney;
  if (temp) {
    temp = temp.replace(/[^0-9.]/g, '');

    // 字符串中有多个点,只保留第一个,其他的过滤掉
    if (temp && temp.length && temp.indexOf('.') != temp.lastIndexOf('.')) {
      var arr = temp.split('.');
      let first = arr.shift();
      temp = first + '.' + arr.join('');
    }
    // 如果小数部分截取最多2位
    if (temp.indexOf('.') != -1) {
      let intergerPart = temp.split('.')[0];
      let decimalPart = temp.split('.')[1];
      if (decimalPart.length > 2) {
        decimalPart = decimalPart.substring(0, 2);
      }
      temp = intergerPart + '.' + decimalPart;
    }

    // 去掉头部多余的0
    while (/^0[0-9]/.test(temp)) {
      temp = temp.substring(1);
    }
  }
  this.purchaseMoney = temp;
},

至此,主要的功能基本满足了,以后发现问题再更新。

在用vant的组件时,看到field组件也是使用了inputmode方案,官网还有特别说明。


cp1001
20 声望0 粉丝