关于VUE的基础认识

44 阅读9分钟

开启掘金成长之旅!这是我参与「掘金日新计划 · 12 月更文挑战」的第2天,点击查看活动详情

VUE 简介

1. 什么是 VUE

  1. 官方给出的概念:vue是一套用于构造用户界面的前端框架

  2. 框架

    • 框架是一套现成的解决方案,程序员只能遵守框架的规范,去编写自己的业务功能!
    • 要学习 VUE,就是在学习 vue 框架中规定的用法!
    • vue 的指令、组件(是对UI结构的复用)、路由、Vuex、vue组件库
    • 只要掌握上面三点,才有开发VUE项目的能力!

2. VUE 的特征

VUE 框架的特性,主要体现在如下两方面:

  1. 数据驱动视图
  2. 双向数据绑定

2.1 数据驱动视图

  • 定义:数据的变化会导致驱动视图的更新
  • 在使用了 vue 的页面中,vue 会监听数据的变化,从而自动重新渲染页面的结构。示意图如下:
  • 好处:当页面数据发生变化时,页面会自动重新渲染!
  • 注意:数据驱动视图是单向的数据绑定

2.2 双向绑定数据

  • 在网页中, from 表单负责采集数据,Ajax负责提交数据

在填写表单时,双向数据绑定可以辅助开发者在不操作 DOM 的前提下,自动 把用户填写的内容同步到数据源中。示意图如下:

  • 好处:开发者不在手动操作 DOM 元素,来获取表单元素最新的值!

2.3 MVVM

MVVM是 vue 实现数据驱动视图和双向数据绑定的核心原理。MVVM指的是Model、View和View和ViewModel,它把每个HTML页面都拆分成了这三个部分,如图所示

  • 在 MVVM 概念中: Model表示当前页面渲染时所依赖的数据源 view表示当前页面所渲染的 DOM 结构 ViewModel表示 vue 的实例,它是MVVM的核心

3. VUE 的指令与过滤器

  1. 指令的概念 指令(Directvies) 是vue为开发者提供的模板语法,用于辅助开发者渲染页面的基本结构

  2. VUE中的指令按照不同的用途可以分为如下6大类:

    • 内容渲染指令
    • 属性绑定指令
    • 事件绑定指令
    • 双向绑定指令
    • 条件渲染指令
    • 列表渲染指令
  • 注意:指令是 vue 开发中最基础、最常用、最简单的知识点。
  1. 内容渲染指令 内容渲染指令用来辅助开发者渲染DOM元素的文本内容。常用的内容渲染指令
  • v-text 指令会覆盖元素内默认的值
  • 用法示例:
<!--把 username 对应的值, 渲染到第一个 p 标签中 -->
<p v-text="username"></p><!--把 username 对应的值, 渲染到第二个 p 标签中 -->
<!-- 注意:第二个 p 标签中,默认的文本 "性别" 会被 gender 的值覆盖掉 -->
<p v-text="gender">性别</p>
  • {{ }} VUE 提供的 {{ }}语法,专门用来解决 v-text 会覆盖默认文本内容的问题。这种{{ }}语法的专业名称是插值表达式
  • 用法示例:
<!-- 使用 {{    }} 插值表达式,将对应的值渲染到元素的内容节点中 -->
<!-- 同时保留元素自身的默认值 -->
<p>姓名:{{username}}</p>
<p>性别:{{gender}}</p>
  • 注意:相对于 V-text 指令来说,插值表达式在开发者更常用一些!因为他不会覆盖元素中默认的文本内容
  • v-html v-text指令和插值表达式只能渲染纯文本内容。如果要把包含HTML标签的字符串渲染为页面的HTML元素,则需要用到 v-html 这个指令:
<!-- 假设 data 中定义了名为 discription 的数据,数据的值为包含 HTML 标签的字符串; -- >
<!-- '<h5 style="color:red;">我在黑马程序员学习 vue.js 课程</h5>' -->
<p v-html="discription"></p>

4. 属性绑定指令

  • 如果需要为元素的属性动态绑定属性值,则需要用到v-bind属性绑定指令。用法示例如下:
<!-- 假设有如下的 data 数据: 
data:{
   inputValue:'请输入内容',
   imgSrc:'https://cn.vuejs.org/images/logo.png'
}
--><!-- 使用 v-bind 指令,为 input 的 placeholder 动态绑定属性值 -->
<input type="text" v-bind:placeholder="inputValue">
<!-- 可以简写为 -->
<input type="text" :placeholder="inputValue">
<br><!-- 使用 v-bind 指令,为 img 的 src 动态绑定属性值 -->
<img v-bind:src="imgSrc" alt="">
<!-- 可以简写为 -->
<img :src="imgSrc" alt="">

5. 使用 JavaScript 表达式

  • 在 vue 提供的模板渲染语法中,除了支持绑定简单的数据值之外,还支持JavaScript表达式的运算例如:
{{number + 1}}
{{ok ? 'YES' : 'NO' }}
{message.split('').reverse().join('') }}
<div v-bind:id="'list-' + id"></div>

6. 事件绑定指令

  • Vue 提供了 v-on事件绑定,用来辅助程序员为 DOM 元素绑定事件监听,语法格式如下:
<h3>count 的值为:{{count}}</h3>
<!-- 语法格式为 v-on: 事件名称="事件处理函数的名称" -->
<button v-on:click="addCount"></button>
  • 注意:原生 DOM 对象有onclick、oninput。onkeyup等原生事件,替换为vue的事件绑定形式后,分为别:v-on:click、v-on:input、v-on:keyup

6-1. 事件绑定指令 ---- V-on

  • 通过 v-on 绑定是hi见处理函数:需要在 methods 节点中进行声明:
   const vm = new Vue({
      // el 属性是 固定的写法,表示当前 vm 实例要控制页面上的哪个区域,接收的值是一个选择器
      el: '#app',
      // data 对象就是要渲染到页面上的数据
      data: {
          count: 0
      },
      // 定义处理函数
      methods: {     // v-on 绑定的事件处理函数,需要声明在 methods 节点中
          addCount(){      // 事件处理函数的名字
            // this 表示当前 new 出来的 vm 实例对象,
            // 通过 this 可以访问到 data 中的数据
            this.count += 1
          }
      }
  })

6-2. 事件绑定简写形式 ---- V-on

  • 由于 v-on 指令在开发中使用频率非常高,因此,vue官方为其提供了简写形式(简写为英文的 @ )
<div id="app">
   <h3>count 的值为:{{count}}</h3>
​
   <!-- 完整写法 -->
   <button v-on:click="addCount">+1</button>
​
   <!-- 简写形式,把 v-on:简写成 @ 符号 -->
   <!-- 如果事件处理函数中的代码足够简单,只有一行代码,则可以简写到行内 -->
   <button @click="count += 1">+1</button>
</div>

7. 事件参数对象

  • 在原生的 DOM 事件绑定中,可以在事件处理函数的形参处,接收事件参数对象event。同理,在v-on 指令 (简写为  @ ) 所绑定的事件处理函数中,同样可以接收到事件参数对象event,示例代码如下:
   <h3>count 的值为:{{count}}</h3>
   <button v-on:click="addCount">+1</button>


methods: {
    addCount(e) {   // 接收事件参数对象 event, 简写为 e
        const nowBgColor=e.target.style.backgroundColor
        e.target.style.backgroundColor = nowBgColor === 'red' ? '' : 'red'
        this.count += 1
    }
}

7-1. 绑定事件并传参

  • 在使用 v-on 指令绑定事件时,可以使用 ( ) 进行传参,实例代码如下:
   <h3>count 的值为:{{count}}</h3>
   <button @click="addNewCount">+2</button>


methods: {
    addCount(step) {   // 在形参处用 step 接收传递过来的参数值
        this.count += step
    }
}

8. $event

  • **event 是vue提供的特殊变量,用来表示原生的事件参数对象 eventevent**  是vue提供的 特殊变量,用来表示 原生的事件参数对象 **event**。event 可以解决事件参数对象 event 被覆盖的问题。示例用法如下:
   <h3>count 的值为:{{count}}</h3>
   <button @click="addNewCount(2,$event)">+2</button>


methods: {
    addNewCount(step) {   // 在形参处用 step 接收传递过来的参数值
         const nowBgColor=e.target.style.backgroundColor
         e.target.style.backgroundColor = nowBgColor === 'cyan' ? '' : 'cyan'
         this.count += step
    }
}

9. 事件修饰符

  • 在事件处理函数中调用 event.preventDefault() 或 event.stopPropagation()  是非常常见的需求。因此, vue 提供了事件修饰符的概念,来辅助程序员更方便的对事件的触发进行控制。常见的5个事件修饰符如下:
事件修饰符说明
.prevent阻止默认行为(例如:阻止 a 链接的跳转、阻止表单的提交等)
.stop阻止事件冒泡
.capture以捕获模式触发当前的事件处理函数
.once绑定的事件只触发 1 次
.self只有在 event.target 是当前元素自身时触发事件处理函数

语法格式如下:

<!-- 触发 click 点击事件时,阻止 a 链接的默认跳转行为 -->
<a href="https://www.baidu.com" $click.prevent="onLinkClick">百度首页</a>

10. 按键修饰符

在监听键盘事件时,我们经常需要判断详细的按键。此时,可以为键盘相关的事件添加</font color="red">按键修饰符,例如:

<!-- 只有在 key 是 enter 时调用 vm.submit() -->
<input @keyup.enter="submit"><!-- 只有在 key 是 esc 时调用 vm.clearInput() -->
<input @keyup.esc="clearInput">

11. 双向绑定事件

vue提供了v-model双向数据绑定命令,用来辅助开发者不操作DOM 的前提下,快速获取表单的数据

<p>用户名是:{{ username }}</p>
<input type="text" v-model="username"><p>选中的省份是:{{province}}</p>
<select v-model="province">
   <option value="">请选择</option>
   <option value="1">北京</option>
   <option value="2">河北</option>
   <option value="3">黑龙江</option>
</select>

12. v-model指令的修饰符

为了方便对用户输入的内容进行处理,vue为v-model 指令提供了 3个修饰符,分别是:

修饰符作用示例
.number自动将用户的输入值转为数值类型
.trim自动过滤用户输入的首尾空白字符
.lazy在"change"时而非"input"时更新
<input type="text" v-model.number="n1">
<input type="text" v-model.number="n2">
<span>{{n1 + n2 }}</span>

13. v-if 和 v-show 的区别

实现原理不同:

  • v-if指令会动态的创建或者移除DOM元素, 从而控制元素在页面上的显示与隐藏;
  • v-show指令会动态为元素添加或移除style="display:none;"样式,从而控制元素的显示与隐藏;

性能消耗不同: v-if 有更高的切换开销,而v-show有更高的初始渲染开销。因此:

  • 如果需要非常频繁地切换,则使用 v-show 较好
  • 如果需要运行时条件很少改变,则使用 v-if 较好

13-1. 条件渲染指令

条件渲染指令用来辅助开发者按需控制DOM的显示与隐藏。条件渲染指令由如下两个:分别是

  • v-if
  • v-show 示例用法如下:
<div id="app">
   <p v-if="networkState === 200">请求成功 --- 被 v-if 控制</p>
   <p v-show="networkState === 200">请求成功 --- 被 v-show 控制</p>
</div>

13-2. v-else

V-if 可以单独使用,或配合 v-else 指令一起使用:

<div v-if="Math.random() > 0.5">
   随机数大于0.5
</div>
<div v-else>
   随机数小于或等于 0.5
</div>
  • 注意:v-else 指令必须配合 v-if 指令一起使用,否则它将不会被识别!

13-3. v-else-if

v-else-if 指令,顾名思义,充当 v-if 的 "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>
  • 注意:v-else-if 指令必须配合 v-if 指令一起使用,否则它将不会被识别!

13-4. 列表渲染指令

VUE 提供了v-for列表渲染指令,用来辅助开发者基于一个数组来循环渲染一个列表结构。v-for指令需要使用item in items 形式的特殊语法,其中:

  • items 是 待循环的数组
  • item 是 被循环的每一项
data:{
   list:[
      // 列表数据
      {id:1,name:'张三'},
      {id:2,name:'李四'}
   ]
}


<ul>
   <li v-for="item in list">姓名是:{{item.name}}</li>
</ul>

13-5. v-for 中的索引

v-for 指令还支持一个 可选的第二个参数,即当前项的索引。语法格式为(item,index) in items,示例代码如下:

data:{
   list:[
      // 列表数据
      {id:1,name:'张三'},
      {id:2,name:'李四'}
   ]
}


<ul>
   <li v-for="(item,index) in list">索引是:{{index}},姓名是:{{item.name}}</li>
</ul>
  • v-for 指令中的item项和index索引都是形参,可以根据需要进行重命名。例如:(user , i) in userlist

14. 使用 key 维护列表的状态

当列表的数据变化时,默认情况下,vue会尽可能的复用已存在的DOM元素,从而提升渲染的性能。但这种默认的性能优化策略,会导致有状态的列表无法被正确更新。 为了给 vue 一个提示,以便它能跟踪每个节点的身份,从而在保证有状态的列表被正确更新的前提下,提升渲染的性能。此时,需要为每项一个唯一的 key 属性:

<!-- 用户列表区域 --->
<ul>
   <!-- 加 key 属性的好处: -->
   <!-- 1. 正确维护列表的状态 -->
   <!-- 2. 复用现有的 DOM 元素,提升渲染的性能 -->
   <li v-for="user in userlist" :key="user.id">
      <input type="checkbox">
      姓名:{{user.name}}
   </li>
</ul>

14-1. key的注意事项

  • key的值只能是字符串或数字类型
  • key的值必须具有唯一性(即:key的值不能重复)
  • 建议把数据项id属性的值作为key的值(因为 id 属性的值具有唯一性)
  • 使用index 的值当作key的值没有任何意义(因为index的值不具有唯一性)
  • 建议使用 v-for 指令时一定要指定key的值(既提升性能、又防止列表状态缭