Vue內置指令的使用

v-model(數據綁定)

v-model常用於表單數據的雙向綁定,它本質上是一個語法糖。它主要的有兩種應用:

  • 在文本框、多行文本、input的下拉框、單選按鈕、複選框中的應用

    <div id="app">
        <input v-model="test">
        <!-- <input :value="test" @input="test= $event.target.value"> -->
        <!--語法糖-->
        <p>{{ test}}</p>
    </div>
    <script>
        new Vue({
            el: '#app',
            data: {
                test: '歡迎來到俠課島'
            }
        });
    </script>

    圖片描述

    下拉框:

    <div id="app">
    <select v-model="selected">
        <option value="設計">Phtotshop</option>
        <option value="編程">programming</option>
        <option value="插畫">Illustration</option>
    </select>
    <span>Selected: {{ selected }}</span>
    </div>
    <script>
        new Vue({
            el: '#app',
            data: {
                selected: ''
            }
        });
    </script>

    單選按鈕:

    <div id="app">
    <input type="radio" id="man" value="男" v-model="picked">
    <label for="man">男</label>
    <br>
    <input type="radio" id="woman" value="女" v-model="picked">
    <label for="woman">女</label>
    <br>
    <input type="radio" id="other" value="其他" v-model="picked">
    <label for="other">其他</label>
    <br>
    <span>Picked: {{ picked }}</span>
    </div>
    <script>
        new Vue({
            el: '#app',
            data: {
                picked: ''
            }
        })
    </script>

    圖片描述

    複選框:

    <div id="app">
    <input type="checkbox" id="one" value="課程一e" v-model.lazy="checkedNames">
    <label for="one">選項一</label>
    <input type="checkbox" id="two" value="課程二" v-model.lazy="checkedNames">
    <label for="two">選項二</label>
    <input type="checkbox" id="three" value="課程三" v-model.lazy="checkedNames">
    <label for="three">選項三</label>
    <br>
    <span>Checked names: {{ checkedNames }}</span>
    </div>
    <script>
        new Vue({
            el: '#app',
            data: {
                checkedNames: []
            }
        })
    </script>

    圖片描述

  • 也可以和.lazy、.trim、.number這些修飾符一起使用
    .lazy

    <input v-model.lazy="test" >

    .number,自動將用戶的輸入值轉爲數值類型

    <input v-model.number="test" type="number">

    trim,自動過濾用戶輸入的首尾空白字符

    <input v-model.trim="test" >

v-for(循環)

格式: v-for=“字段名 in(of) 數組 or json

<div id="main">
    <p>{{ message }}</p>
    <ul>
      <li v-for="(item,index) in fruit">{{ item }} {{ index }}</li>
    </ul>
</div>
<script>
    new Vue({
      el: '#main',
      data: {
        message: 'Welcome XKD!',
        fruit: [
          'Apple',
          'Grape',
          'Pitaya',
          'Banana',
          'watermelon',
          'Pomegranate'
        ]
      }
    })
</script>

圖片描述

v-show 和 v-if(顯示與隱藏)、v-else-if、v-else

v-show 通過值來判斷是否加載並顯示;

v-if 通過值來判斷是否加載;

v-else-if ,充當 v-if 的“else-if 塊”,可以連續使用;

v-else ,表示 v-if 的“else 塊” ,必須連用,否則無效不會識別。

v-show 和 v-if兩者區別在於:

  • v-if 控制元素隱藏的時候,它會刪除dom節點,而v-show並不會,v-if還可以和v-else-if 和 v-else,這兩者是必須和v-if連用,不能單獨使用。
  • 一般來說, v-if 有更高的切換開銷,而 v-show 有更高的初始渲染開銷。

    如果需要非常頻繁地切換,則使用 v-show 較好;如果在運行時條件不太可能改變,則使用 v-if 較好。

v-show:

<div v-show="isShow">我只是用來控制 display 的屬性值</div>

<script>
    var vm = new Vue({
        el: "#main",
        data: {
            isShow: true
        }
    });
</script>

v-if:

<div id="main">
    <div v-if="isShow">顯示或隱藏</div>
</div>
<script>
    var vm = new Vue({
        el: "#main",
        data: {
            isShow: fasle
        }
    });
</script>

v-else-if:

<div v-if="type === 'A'">程序員</div>
<div v-else-if="type === 'B'">設計師</div>
<div v-else-if="type === 'C'">運營者</div>
<div v-else>互聯網工作人</div>

<script>
    var vm = new Vue({
        el: "#main",
        data: {
            type: 'A'
        }
    });
</script>

v-else:

<div v-if="isTrue">俠課島</div>
<div v-else>還是俠課島</div>

<script>
    var vm = new Vue({
        el: '#main',
        data: {
            isTrue: true
        }
    })
</script>

v-bind(動態綁定)

及時對頁面的數據進行更新修改。

  • v-bind:id 簡寫爲 :id
  • v-bind:disabled 簡寫爲 :disabled
  • v-bind:href 簡寫爲 :href
  • v-on:click 簡寫爲 @click

v-on(綁定事件)

指令綁定事件後,就會監聽相應的事件。

v-on:click:

<div id="main">
    <h3>已點擊 {{count}} 次</h3>
    <button @click="count++">Click Me!</button>
</div>
<script>
    var vm = new Vue({
      el: '#main',
      data: {
        count: 0
      }
    });
</script>

v-on:keyup:先顯示值,再彈出層

<div id="main">
    <input v-on:keyup.13="keyup" type="text">
</div>
<script>
    var vm = new Vue({
      el: '#main',
      data: {
      },
      methods: {
        // enterClick: function () {
        //   console.log("enterClick");
        // }
        keyup(e) {
          alert(JSON.stringify(e));
        }
      }
    });
</script>

v-on:keydown:在框中輸入先彈出層,再顯示輸入的值

<div id="main">
    <input v-on:keydown="keydown">
</div>
<script>
    var vm = new Vue({
      el: '#main',
      data: {
      },
      methods: {
        keydown(e) {
          alert(JSON.stringify(e));
        }
      }
    });
</script>

v-text 和 v-html(解析文本)

v-text:

<span v-text="dangerHTML"></span>

dangerHTML: '<span onclick="alert(123)">123</span>'

不管是什麼,全都解析成文本,裏面的HTML標籤也全部轉義掉:
圖片描述
v-html:

<span v-html="dangerHTML"></span>

dangerHTML: '<span onclick="alert(123)">123</span>'

圖片描述

v-bind:class

  • 對象:{ red:ifAbledRed }
    圖片描述
  • 三目運算符:ifAbledRed ? "red" : "blue"
  • 數組:[{red:"ifAbledRed"},{blue:"ifAbledBlue"}]

v-once

只渲染一次,不再進行渲染。

<p v-once>{{ message }}</p>

v-cloak(防止閃爍)

v-cloak一般是配合 [v-cloak] {display: none; }css 一起使用的。

<p v-cloak>{{ message }}</p>

下面是一個閃爍的截圖代碼,當我們給如下紅色代碼塊外加一個setTimeout時間延遲時,然後再去執行我們會發現在網頁上什麼都沒有,會有一個時間的停留,因此提供了一個v-cloak的方法來解決這個問題。
圖片描述

v-pre

原位輸出標籤內部的元素。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章