Vue.js按鍵修飾符及v-model修飾符示例詳解
一、按鍵修飾符
v-on指令用來進行事件監(jiān)聽(如單擊事件、鍵盤事件等)
v-on監(jiān)聽鍵盤事件的基本使用示例:
<div id="root">
<input type="text" v-on:keyup="counter+=1">
<p>在輸入框輸入了{{counter}}個字符</p>
</div>
<script>
Vue.config.productionTip = false;
const vm = new Vue({
el: '#root',
data: {
counter: 0
},
methods: {
}
})
</script>執(zhí)行結果:

在監(jiān)聽鍵盤事件時,經常需要檢查詳細的按鍵。Vue.js允許為v-on在監(jiān)聽鍵盤事件時添加按鍵修飾符。例如:
<!-- 只有在'key'是'enter'時調用'submit()'--> <input v-on:keyup.enter="submit()"> <!-- 縮寫語法 --> <input @keyup.enter="submit">
下面列出官方提供的所有按鍵修飾符別名:
.enter => //enter鍵 .tab => //tab鍵 .delete (捕獲"刪除"和"退格"按鍵) => //刪除鍵 .esc => //取消鍵 .space => //空格鍵 .up => //上 .down => //下 .left => //左 .right => //右
(1)回車鍵按鍵修飾符示例
<div id="root">
<input type="text" v-model="content" v-on:keyup.enter="fun(content)">
</div>
<script>
Vue.config.productionTip = false;
const vm = new Vue({
el: '#root',
data: {
content: ''
},
methods: {
fun:function(data){
alert('錄入內容為:'+data);
this.content='';
}
}
})
</script>執(zhí)行結果:

在input框中輸入"夏志121"后按下回車鍵,松開回車鍵后在瀏覽器中將彈出對話框"錄入內容為:夏志121"。
(2)自定義按鍵修飾符示例
Vue.js還支持自定義按鍵修飾符,可以利用按鍵對應的鍵碼來實現,可以把上面的功能改成松開F2后彈出輸入的內容,而F2對應的鍵碼是113,那么久可以對代碼進入如下修改:
<div id="root">
<input type="text" v-model="content" v-on:keyup.113="fun(content)">
</div>
<script>
Vue.config.productionTip = false;
const vm = new Vue({
el: '#root',
data: {
content: ''
},
methods: {
fun:function(data){
alert('錄入內容為:'+data);
this.content='';
}
}
})
</script>執(zhí)行結果:

在input框中輸入"你好"后按下F2,松開F2后在瀏覽器中將彈出"錄入內容為:你好"。
二、v-model修飾符
v-model可以實現表單元素和數據的雙向綁定。與事件修飾符類似,v-model指令也有修飾符,用于控制數據同步的機制。
(1).lazy
v-model默認是在input事件中同步輸入框中的內容的,即一旦有數據發(fā)生改變,對應data中的數據就會自動發(fā)生改變。若使用lazy修飾符,可以讓數據在失去焦點或回車時會更新。
v-model的lazy修飾符使用示例:
<div id="root">
<input v-model.lazy="content">
<div>{{content}}</div>
</div>
<script>
Vue.config.productionTip = false;
const vm = new Vue({
el: '#root',
data: {
content:"這是content"
},
methods: {
}
})
</script>執(zhí)行結果:

(2).number
默認情況下,在輸入框中輸入的內容會被當作字符串類型進行處理,這是HTML的底層邏輯造成的,如果加上number修飾符,就可以讓你在輸入數字的時候將輸入的內容轉換成number類型。
v-model的number修飾符使用示例:
<div id="root"><br><br>
<input v-model="content1">
<div>【不加number修飾符】輸入內容:{{content1}}</div>
<div>【不加number修飾符】數據類型:{{typeof content1}}</div>
<input v-model.number="content2">
<div>【不加number修飾符】輸入內容:{{content2}}</div>
<div>【不加number修飾符】數據類型:{{typeof content2}}</div>
</div>
<script>
Vue.config.productionTip = false;
const vm = new Vue({
el: '#root',
data: {
content1:"這是content1",
content2:"這是content2"
},
methods: {
}
})
</script>執(zhí)行結果:
分別在第一個輸入框和第二個輸入框中輸入"121",在瀏覽器生成的內容如下:

(3).trim
trim修飾符可以去除輸入內容左右兩邊的空格。
v-model的trim修飾符使用示例:
<div id="root">
<input v-model.trim="content">
<div>輸入內容:{{content}}</div>
</div>
<script>
Vue.config.productionTip = false;
const vm = new Vue({
el: '#root',
data: {
content:"content"
},
methods: {
}
})
</script>執(zhí)行結果:

到此這篇關于Vue.js按鍵修飾符及v-model修飾符的文章就介紹到這了,更多相關Vue.js v-model修飾符內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
vue2.0 實現導航守衛(wèi)的具體用法(路由守衛(wèi))
這篇文章主要介紹了vue2.0 實現導航守衛(wèi)的具體用法(路由守衛(wèi)),vue-route 提供的 beforeRouteUpdate 可以方便地實現導航守衛(wèi)(navigation-guards),具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-05-05

