亚洲免费在线视频-亚洲啊v-久久免费精品视频-国产精品va-看片地址-成人在线视频网

您的位置:首頁技術文章
文章詳情頁

javascript - vue 移動端的input 數字輸入優化

瀏覽:81日期:2023-02-27 09:13:01

問題描述

這是移動端使用的, 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, ’’) } }})

標簽: JavaScript
相關文章:
主站蜘蛛池模板: 国产成a人片在线观看视频 国产成版人视频网站免费下 | 成人三级在线观看 | 一区二区三区视频在线 | 69视频在线观看xxxxx | 久久夜色精品国产亚洲 | 欧美综合在线观看 | 亚洲在线播放视频 | 亚洲国产网址 | 免费va国产高清不卡大片 | 亚洲haose在线观看 | 亚洲性视频在线 | 萌白酱粉嫩jk福利在线观看 | 欧美久在线观看在线观看 | 特级深夜a级毛片免费观看 特级生活片 | 国产黄色美女 | 中文精品久久久久国产网址 | 大量真实偷拍情侣视频野战 | 婷婷国产成人久久精品激情 | 中文字幕欧美在线观看 | avwww在线| 手机看片福利永久 | 久久频这里精品香蕉久久 | 日韩一级片在线播放 | 日本特黄特色高清免费视频 | 久久影院一区二区三区 | 欧美日韩ay在线观看 | 国产中文字幕视频 | 国产高清日韩 | 日韩中文字幕在线视频 | 亚洲偷| 精品欧美激情在线看 | 久久国产精品一国产精品 | 日韩三级在线 | 午夜精品久久久久久91 | 亚洲视频一区二区在线观看 | 中国美女一级片 | 亚洲精品自拍 | 欧美视频一区 | 欧美一级www片免费观看 | 那里有黄色网址 | 欧美亚洲一级片 |