1、{{}}

插值表达式,绑定vue中的data数据

  1. <!-- id标识vue作用的范围 -->
  2. <div id="app">
  3. <!-- {{}} 插值表达式,绑定vue中的data数据 -->
  4. {{ message }}
  5. </div>
  6. <script src="vue.min.js"></script>
  7. <script>
  8. // 创建一个vue对象
  9. new Vue({
  10. el: '#app',//绑定vue作用的范围
  11. data: {//定义页面中显示的模型数据
  12. message: 'Hello Vue!'
  13. }
  14. })
  15. </script>

2、v-bind

单向数据绑定

你看到的 v-bind 特性被称为指令。指令带有前缀 v-

除了使用插值表达式{{}}进行数据渲染,也可以使用 v-bind指令,它的简写的形式就是一个冒号(:)

  1. <!-- 如果要将模型数据绑定在html属性中,则使用 v-bind 指令
  2. 此时title中显示的是模型数据
  3. -->
  4. <h1 v-bind:title="message">
  5. {{content}}
  6. </h1>
  7. <!-- v-bind 指令的简写形式: 冒号(:) -->
  8. <h1 :title="message">
  9. {{content}}
  10. </h1>

3、v-model

双向数据绑定

  1. data: {
  2. searchMap:{
  3. keyWord: '还有我'
  4. }
  5. }
  1. <!-- v-bind:value只能进行单向的数据渲染 -->
  2. <input type="text" v-bind:value="searchMap.keyWord">
  3. <!-- v-model 可以进行双向的数据绑定 -->
  4. <input type="text" v-model="searchMap.keyWord">
  5. <p>您要查询的是:{{searchMap.keyWord}}</p>

4、事件

v_on

使用 v-on 进行数件处理,v-on:click 表示处理鼠标点击事件,事件调用的方法定义在 vue 对象声明的 methods 节点中

  1. <!-- v-on 指令绑定事件,click指定绑定的事件类型,事件发生时调用vue中methods节点中定义的方法 -->
  2. <button v-on:click="search()">查询</button>
  3. <p>您要查询的是:{{searchMap.keyWord}}</p>
  4. <p><a v-bind:href="result.site" target="_blank">{{result.title}}</a></p>

简写:

  1. <!-- v-on 指令的简写形式 @ -->
  2. <button @click="search()">查询</button>

5、修饰符

修饰符 (Modifiers) 是以半角句号(.)指明的特殊后缀,用于指出一个指令应该以特殊方式绑定。

例如,.prevent 修饰符告诉 v-on 指令对于触发的事件调用 event.preventDefault():

即阻止事件原本的默认行为

  1. <!-- 修饰符用于指出一个指令应该以特殊方式绑定。
  2. 这里的 .prevent 修饰符告诉 v-on 指令对于触发的事件调用js的 event.preventDefault():
  3. 即阻止表单提交的默认行为 -->
  4. <form action="save" v-on:submit.prevent="onSubmit">
  5. <label for="username">
  6. <input type="text" id="username" v-model="user.username">
  7. <button type="submit">保存</button>
  8. </label>
  9. </form>

@click.stop..prevent=”hello”

  • .stop:阻止事件冒泡到父元素
  • .prevent:阻止默认事件发生
  • .capture:使用事件捕获模式
  • .self:只有元素自身触发事件才执行。(冒泡或捕获都不执行)
  • .once:只执行一次

    6、条件渲染

v-if:条件指令

  1. data: {
  2. ok: false
  3. }
  1. <input type="checkbox" v-model="ok">同意许可协议
  2. <!-- v:if条件指令:还有v-else、v-else-if 切换开销大 -->
  3. <h1 v-if="ok">if:Lorem ipsum dolor sit amet.</h1>
  4. <h1 v-else>no</h1>

v-show:条件指令

  1. <!-- v:show 条件指令 初始渲染开销大 -->
  2. <h1 v-show="ok">show:Lorem ipsum dolor sit amet.</h1>
  3. <h1 v-show="!ok">no</h1>

优缺点:

  • v-if 是“真正”的条件渲染,因为它会确保在切换过程中条件块内的事件监听器和子组件适当地被销毁和重建。
  • v-if 也是惰性的:如果在初始渲染时条件为假,则什么也不做——直到条件第一次变为真时,才会开始渲染条件块。
  • 相比之下,v-show 就简单得多——不管初始条件是什么,元素总是会被渲染,并且只是简单地基于 CSS 进行切换。
  • 一般来说,v-if 有更高的切换开销,而 v-show 有更高的初始渲染开销。因此,如果需要非常频繁地切换,则使用 v-show 较好;如果在运行时条件很少改变,则使用 v-if 较好。

7、列表渲染

v-for:列表循环指令

例1:简单的列表渲染

  1. <!-- 1、简单的列表渲染 -->
  2. <ul>
  3. <li v-for="n in 10">{{ n }} </li>
  4. </ul>
  5. <ul>
  6. <!-- 如果想获取索引,则使用index关键字,注意,圆括号中的index必须放在后面 -->
  7. <li v-for="(n, index) in 5">{{ n }} - {{ index }} </li>
  8. </ul>

例2:遍历数据列表

  1. data: {
  2. userList: [
  3. { id: 1, username: 'helen', age: 18 },
  4. { id: 2, username: 'peter', age: 28 },
  5. { id: 3, username: 'andy', age: 38 }
  6. ]
  7. }
  1. <!-- 2、遍历数据列表 -->
  2. <table border="1">
  3. <!-- <tr v-for="item in userList"></tr> -->
  4. <tr v-for="(item, index) in userList">
  5. <td>{{index}}</td>
  6. <td>{{item.id}}</td>
  7. <td>{{item.username}}</td>
  8. <td>{{item.age}}</td>
  9. </tr>
  10. </table>