1.Vue基础语法
1.1 Vue概述
1.1.1Vue是什么?
用于构建用户界面的渐进式 框架
声明式渲染→组件系统→客户端路由→集中式状态管理→项目构建
vue 的核心库只关注视图层
1.1.2Vue有哪些优点?
易用、灵活、高效 简单易上手
1.2 vue基本使用
1.2.1如何利用Vue将hello world 渲染到页面上?
1、需要提供标签用于填充数据 注意: 在标签中我们使用插值语法的形式 即 {{}} 进行填充数据
2、引入vue.js库文件 注意:一定要先引入Vue文件 在使用Vue语法 因为存在作用域的问题
3、使用vue的语法做功能: new Vue() 创建一个Vue的实例 ,在构造函数中以对象的形式做一些配置
4、利用Vue将数据渲染到页面上,数据写在data 里面
1.2.2 Hello Vue之细节分析
1. 实例参数分析
⚫ el: 元素的挂载位置(值可以是CSS选择器或者DOM元素)
⚫ data:模型数据(值是一个对象)
2. 插值表达式用法
⚫ 将数据填充到HTML标签中
⚫ 插值表达式支持基本的计算操作
3. Vue代码运行原理分析
⚫ 概述编译过程的概念(Vue语法→
原生语法)
1.3 Vue模板语法
1.3.1 如何理解前端渲染?
把数据填充到HTML标签中: 模板 + 数据 →前端渲染→静态HTML内容
1.3.2 把字符串渲染到页面上有哪些方式?
1.利用原生js拼接字符串 (代码差异大,维护困难)
2.利用模板引擎拼接 (基于模板引擎art-template,没有专门提供事件机制)
3.利用Vue插值语法
4.文档碎片 document.createDocumentFragment
5.利用es6 `` 反引号拼接字符串
1.3.3 什么是指令?
指令的本质就是自定义属性,格式以v-开始
1.3.4 为什么会有闪烁问题?
代码加载的时候先加载HTML 把插值语法当做HTML内容加载到页面上 当加载完js后才把插值语法替换掉 所以我们会看到闪烁问题
解决插值语法闪烁问题 :使用v-cloak
在指令中不要写插值语法,直接写对应的变量名称 ;在 v-text
中赋值的时候不要在写插值语法 ;一般属性中不加 {{}}
直接写 对应的数据名;
Vue 中只有在标签的 内容中 才用插值语法
1.3.5 数据绑定指令
⚫ v-text 填充纯文本
①
用于将数据填充到标签中,作用于插值表达式类似,但是没有闪动问题 ,
相比插值表达式更加简洁
②
如果数据中有
HTML
标签会将
html
标签一并输出
注意:此处为单向绑定,数据对象上的值改变,插值会发生变化;但是当插值发生变化并不会影响数据对象的
值
⚫ v-html 填充HTML片段
① 存在安全问题
② 本网站内部数据可以使用,来自第三方的数据不可以用
注意:v-text输出的是纯文本,浏览器不会对其再进行html解析;html会将其当html标签解析后输出;可能有安全问题, 一般只在可信任内容上使用 v-html ,永不 用在用户提交的内容上
⚫ v-pre 填充原始信息
① 显示原始信息,跳过编译过程(分析编译过程)
② 一些静态的内容不需要编译加这个指令可以加快渲染
1.3.6 数据响应式
⚫ 如何理解响应式
① html5中的响应式(屏幕尺寸的变化导致样式的变化)
② 数据的响应式(数据的变化导致页面内容的变化)
⚫ 什么是数据绑定
① 数据绑定:将数据填充到标签中
⚫ v-once 只编译一次
① 显示内容之后不再具有响应式功能:
执行一次性的插值【当数据改变时,插值处的内容不会继续更新】
1.3.7 双向数据绑定(v-model)
1.什么是双向数据绑定:当数据发生变化的时候,视图也就发生变化 ;当视图发生变化的时候,数据也会跟着同步变化
2.使用场景:v-model是一个指令,限制在 、、
3.MVVM:
MVC
是后端的分层开发概念;
MVVM
是前端视图层的概念,主要关注于 视图层分离,也就是说:
MVVM
把前端的视图层,分为了三部分 Model, View , VM ViewModel
① m model :数据层Vue中数据层都放在 data 里面
② v view 视图 :Vue中 view 即我们的 HTML 页面
③ vm ( view-model ) 控制器 将数据和视图层建立联系 :vm即 Vue 的实例
4. v-model的低层实现原理分析
v-bind绑定属性值,v-on处理值变化这个事件
第一种方案 :
通过 v-on监听输入框的输入事件 将输入的值通过事件处理函数存到data中 给输入框通过v-bind 绑定属性 value 把数据渲染到页面上
第二种方案 :
通过 v-on监听输入框的输入事件 通过事件对象$event 拿到输入的值 直接存储到data中 给输入框通过v-bind 绑定属性 value 把数据渲染到页面上
1.3.8 事件绑定
1.v-on :用来绑定事件;形式如:v-on:click ,
缩写为
@click
2.事件函数的调用方式
① 直接绑定函数名称调用 点击1
② 调用函数的形式 点击1
如果事件直接绑定函数名称,那么默认会传递事件对象作为事件函数的第一个参数。 如果事件绑定函数调用,那么事件对象必须作为最后一个参数显示传递, 并且事件对象的名称必须是$event
3.事件修饰符
在事件处理程序中调用
event.preventDefault()
或
event.stopPropagation()
是非常常见的需求。
Vue
不推荐我们操作
DOM
为了解决这个问题,
Vue.js
为
v
-
on
提供了
事件修饰符
修饰符是由点开头的指令后缀来表示的
使用修饰符时,
顺序很重要
;相应的代码会以同样的顺序产生。因此,用
v-on:click.prevent.self
会阻止所有的点
击,而
v-on:click.self.prevent
只会阻止对元素自身的点击。
4. 按键修饰符
Vue
允许为
v
-
on
在监听键盘事件时添加按键修饰符
5.自定义按键修饰符别名
在 Vue 中可以通过 config.keyCodes 自定义按键修饰符别名 ,如 Vue.config.keyCodes.f1 = 112
1.3.9 属性绑定
1.Vue中动态处理属性: v-bind 指令被用来响应地更新 HTML 属性 ,v-bind:href 可以缩写为 :href
注意:v-bind 和 v-on的区别 v-bind 绑定属性 v-on 绑定事件
2.绑定对象 : 通过v-bind:class = { 键: 值 } 键 代表一个类名,如果这个值为true表示显示这个类名,如果这个值为false表示不显示这个类
注意:v-bind:class 指令可以与普通的 class 特性共存
3.绑定数组: 通过v-bind:class =[ 值1,值2 ] 值1、值2 对应 data 中的 数据
4.
绑定对象和绑定数组的区别:
绑定对象的时候 对象的属性 即要渲染的类名 对象的属性值对应的是
data
中的数据
绑定数组的时候数组里面存的是
data
中的数据
注意:对象绑定和对象数组可以混用
5.
绑定style:
属性名可以用驼峰式
(camelCase)
或短横线分隔
(kebab-case
,记得用单引号括起来
)
组语法可以将多个样式对象应用到同一个元素
也可以使用对象和数组:
v-bind:style = [值1, 值2 ] ,数组中的值1 和值2 中存储的是一个对象,这个对象里面存储的css属性和属性值
v-bind:style = { 键: 值 } ,键代表CSS的属性,值中存贮的是CSS 属性值
1.3.10 分支循环结构 1.
分支结构
⚫ v-if
1- 多个元素 通过条件判断展示或者隐藏某个元素。或者多个元素
2-
进行两个视图之间的切换
⚫ v-else
⚫ v-else-if
⚫ v-show
2.
v-if与v-show的区别
⚫ v-if控制元素是否渲染到页面:v-if是动态的向DOM树内添加或者删除DOM元素
v-if 切换有一个局部编译 / 卸载的过程,切换过程中合适地销毁和重建内部的事件监听和子组件
⚫ v-show控制元素是否显示( 已经渲染到了页面 ):v-show本质就是标签display设置为none,控制隐藏
v-show 只编译一次,后面其实就是控制 css ,而 v-if 不停的销毁和创建,故 v-show 性能更好一点
3.循环结构
v-for :用于循环的数组里面的值可以是对象,也可以是普通元素
⚫ v-for遍历对象
不推荐 同时使用 v-if 和 v-for ,当 v-if 与 v-for 一起使用时, v-for 具有比 v-if 更高的优先级
⚫ v-if和v-for结合使用
4. key的作用:
key来给每个节点做一个唯一标识 ;key的作用主要是为了高效的更新虚拟DOM;
帮助Vue区分不同的元素,从而提高性能
1.4 Vue 常用特性
⚫ 表单操作
⚫ 自定义指令
⚫ 计算属性
⚫ 侦听器
⚫ 过滤器
⚫ 生命周期
1.4.1 表单操作
1.获取单选框中的值 (通过v-model)
2.获取复选框中的值(通过 v-model): 和获取单选框中的值一样 ,复选框 checkbox 这种的组合时 data 中的 hobby 我们要定义成数组 否则无法实现多选
3.获取下拉框和文本框中的值(通过 v-model)
4.表单域修饰符
.number
转换为数值:
注意点:
当开始输入非数字的字符串时,因为Vue
无法将字符串转换成数值 ,所以属性值将实时更新成相同的字符串。即使后面输入数字,也将被视作字符串
.trim
自动过滤用户输入的首尾空白字符:只能去掉首尾的 不能去除中间的空格
.lazy
将
input
事件切换成
change
事件:.lazy 修饰符延迟了同步更新属性值的时机。即将原本绑定在
input
事件的同步逻辑转变为绑定在
change 事件上 ,
在失去焦点 或者 按下回车键时才更新
1.4.2自定义指令
1.Vue.directive
注册全局指令
2.Vue.directive
注册全局指令 带参数
3.自定义指令局部指令
局部指令,需要定义在
directives
的选项 用法和全局用法一样 ;
局部指令只能在当前组件里面使用
;当全局指令和局部指令同名时以局部指令为准
1.4.3 计算属性 computed
模板中放入太多的逻辑会让模板过重且难以维护 使用计算属性可以让模板更加的简洁 ;
计算属性是基于它们的响应式依赖进行缓存的,方法不存在缓存;
computed比较适合对多个变量或者对象进行处理后返回一个结果值,也就是数多个变量中的某一个值发生了变化,则我们监控的这个值也就会发生变化
1.4.4 侦听器 watch
使用
watch
来响应数据的变化 ,一般用于异步或者开销较大的操作 ,watch 中的属性 一定是
data
中 已经存在的数据
当需要监听一个对象的改变时,普通的
watch
方法无法监听到对象内部属性的改变,只有
data
中的数据才能够
监听到变化,此时就需要
deep
属性对对象进行深度监听
1.4.5过滤器
作用: 格式化数据,比如将字符串格式化为首字母大写,将日期格式化为指定的格式等
1.Vue.js
允许自定义过滤器,可被用于一些常见的文本格式化
Vue.filter(‘过滤器名称’, function(value){
// 过滤器业务逻辑
})
2.过滤器可以用在两个地方:双花括号插值和
v-bind
表达式
{{msg | upper}}
{{msg | upper | lower}}
3.过滤器应该被添加在
JavaScript
表达式的尾部,由
“
管道
”
符号指示 支持级联操作
4.过滤器不改变真正的
data
,而只是改变渲染的结果,并返回过滤后的版本
5.全局注册时是
fifilter
,没有
s
的。而局部过滤器是
fifilters
,是有
s
的
Vue.filter 全局 Filters 局部
filters:{
capitalize: function(){}
}
过滤器中传递参数
Vue.filter(‘format’, function(value, arg1){
// value就是过滤器传递过来的参数
})
{{date | format(‘yyyy-MM-dd')}}
1.4.6 生命周期
1.事物从出生到死亡的过程 ;Vue实例从创建 到销毁的过程 ,这些过程中会伴随着一些函数的自调用。我们称这些函数为钩子函数
2.主要阶段:挂载(初始化相关属性)→更新(元素或组件的变更操作)→销毁(销毁相关属性)
3.常用的 钩子函数
4.Vue实例的产生过程
① beforeCreate 在实例初始化之后,数据观测和事件配置之前被调用。
② created 在实例创建完成后被立即调用。
③ beforeMount 在挂载开始之前被调用。
④ mounted el被新创建的vm.$el替换,并挂载到实例上去之后调用该钩子。
⑤ beforeUpdate 数据更新时调用,发生在虚拟DOM打补丁之前。
⑥ updated 由于数据更改导致的虚拟DOM重新渲染和打补丁,在这之后会调用该钩子。
⑦ beforeDestroy 实例销毁之前调用。
⑧ destroyed 实例销毁后调用。
1.4.7 数组变异方法
在vue中,直接修改对象属性的值无法触发响应式(直接修改对象属性的值,数据修改了,但是页面内容没有变),变异数组方法即保持数组方法原有功能不变的前提下对其进行功能拓展
1.4.8 替换数组
不会改变原始数组,但总是返回一个新数组
变异方法和替换数组有什么区别 :变异的方法能够实现数据更新视图自动更新 替换数组 不会修改原始数据 导致 数据改变 视图不一定更新
1.4.9 动态处理响应式数据
⚫Vue.set(vm.items, indexOfItem, newValue)
⚫ vm.$set(vm.items, indexOfItem, newValue)
① 参数一表示要处理的数组名称
② 参数二表示要处理的数组的索引
③ 参数三表示要处理的数组的值