javascript - vue 移动端的input 数字输入优化
问题描述
这是移动端使用的, input type 为number 时 英文或中文都没有限制,而且maxlength不起作用,input type 为tel 时 英文或中文也都没有限制,但maxlength有作用,所以用tel,keyup 是为了过滤数字以外的字符。请问大神这段代码还有没有优化的空间?
<input v-model='phoneNumber' placeholder='输入手机号' type='tel' maxlength='11' @keyup='handleFilterLetters'><script type='text/javascript'> vm = new Vue({ el: '#app', data: {phoneNumber: null, }, methods: {handleFilterLetters: function(){ var self = this; self.phoneNumber=self.phoneNumber.replace(/[^d]/g,’’);}, }})</script>
问题解答
回答1:phoneNumber 初始值应该是字符串的 ’’,否则对一个可能为 null 的变量调用 replace 是不安全的。
var self = this 是不必要的。
handleFilterLetters 好长啊,改成 onKeyUp 不好读一点吗(
<input> 一行写的太长了,eslint-airbnb 的规则是
<input v-model='phoneNumber' placeholder='输入手机号' type='tel' maxlength='11' @keyup='handleFilterLetters'/>回答2:
楼上说的都对题主还可以多注意一下 code style 比如:self.phoneNumber=self.phoneNumber.replace(/[^d]/g,’’);
写成self.phoneNumber = self.phoneNumber.replace(/[^d]/g,’’);
比较好
回答3:这里用的局部filter
如果想可复用程度高点,全局filter也可以的
<p > <input :value='phone | num' @keyup='phoneChange' /></p>
var app = new Vue({ el: '#app', data: { phone: '' }, methods: { phoneChange(e) { this.phone = e.target.value this.$forceUpdate() // 这里必须有 } }, filters: { ’num’: function(value) { return value.replace(/[^d]/g, ’’) } }})
相关文章:
1. windows - asp.net连接上mysql之后如何调用?比如下面的登录验证功能怎么实现2. css3 - Typecho 后台部分表单按钮在 Chrome 下出现灵异动画问题,求解决3. javascript - 编程,算法的问题4. 刚放到服务器的项目出现这中错误,有高手指点吗5. mysql - 面试题:如何把login_log表转换成last_login表?6. javascript - 为什么嵌套的Promise不能按预期捕获Exception?7. java - HTTPS双向认证基础上有无必要再进行加签验签?8. apache - 想把之前写的单机版 windows 软件改成网络版,让每个用户可以注册并登录。类似 qq 的登陆,怎么架设服务器呢?9. javascript - nodejs实现异步时遇到的一个问题10. java - 阿里的开发手册中为什么禁用map来作为查询的接受类?
