午夜剧场伦理_日本一道高清_国产又黄又硬_91黄色网战_女同久久另类69精品国产_妹妹的朋友在线

您的位置:首頁技術(shù)文章
文章詳情頁

javascript - vue 移動端的input 數(shù)字輸入優(yōu)化

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

問題描述

這是移動端使用的, input type 為number 時 英文或中文都沒有限制,而且maxlength不起作用,input type 為tel 時 英文或中文也都沒有限制,但maxlength有作用,所以用tel,keyup 是為了過濾數(shù)字以外的字符。請問大神這段代碼還有沒有優(yōu)化的空間?

<input v-model='phoneNumber' placeholder='輸入手機(jī)號' 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 初始值應(yīng)該是字符串的 ’’,否則對一個可能為 null 的變量調(diào)用 replace 是不安全的。

var self = this 是不必要的。

handleFilterLetters 好長啊,改成 onKeyUp 不好讀一點嗎(

<input> 一行寫的太長了,eslint-airbnb 的規(guī)則是

<input v-model='phoneNumber' placeholder='輸入手機(jī)號' 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

如果想可復(fù)用程度高點,全局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, ’’) } }})

標(biāo)簽: JavaScript
相關(guān)文章:
主站蜘蛛池模板: 青青草原亚洲 | 国产特黄 | 精品成人18| 1级黄色大片 | 91色在线视频 | 青青操免费在线视频 | 午夜在线看片 | 91免费版黄色 | 一曲二曲三曲在线观看中文字幕动漫 | 欧美午夜影院 | 免费一级黄色 | 麻豆蜜桃视频 | 在线播放毛片 | 精品视频久久久久久 | 黄色一级视频免费看 | 成人免费网站 | 欧美性猛交xxxx乱大交少妇 | 性欧美一区 | 日韩视频成人 | 日韩美女中文字幕 | 国产精品11 | 日本视频中文字幕 | 亚洲天堂视频在线播放 | 久久亚洲视频 | 一区二区三区视频免费 | 72成人网 | 久久草视频在线 | 日韩一区三区 | 成人羞羞国产免费 | 久久国产精品一区二区 | 欧美日韩一区三区 | 懂色av一区二区三区四区五区 | 毛片视频免费观看 | 午夜视频网址 | 黄色片免费播放 | 成人99视频 | 精品热久久 | 成人av免费观看 | 毛片毛片毛片毛片毛片毛片毛片 | 一区二区国产在线 | 91精品国产99久久久久久红楼 |