Vue.js按鍵修飾符及v-model修飾符示例詳解

一、按鍵修飾符

v-on指令用來進行事件監聽(如單擊事件、鍵盤事件等)

v-on監聽鍵盤事件的基本使用示例:

 <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>

執行結果:

在監聽鍵盤事件時,經常需要檢查詳細的按鍵。Vue.js允許為v-on在監聽鍵盤事件時添加按鍵修飾符。例如:

<!-- 隻有在'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>

執行結果:

        在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>

執行結果:

在input框中輸入"你好"後按下F2,松開F2後在瀏覽器中將彈出"錄入內容為:你好"。

二、v-model修飾符

        v-model可以實現表單元素和數據的雙向綁定。與事件修飾符類似,v-model指令也有修飾符,用於控制數據同步的機制。

(1).lazy

        v-model默認是在input事件中同步輸入框中的內容的,即一旦有數據發生改變,對應data中的數據就會自動發生改變。若使用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>

執行結果:

(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>

執行結果:

分別在第一個輸入框和第二個輸入框中輸入"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>

 執行結果:

到此這篇關於Vue.js按鍵修飾符及v-model修飾符的文章就介紹到這瞭,更多相關Vue.js v-model修飾符內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!

推薦閱讀: