Vue针对性笔记
Github原文阅读
MVVM(Model-View-ViewModel)模型
MVVM
分为Model
、View
、ViewModel
三部分。
Model
代表数据模型,定义数据和业务逻辑,访问数据层View
代表视图,展示页面结构、布局和外观(UI)ViewModel
代表视图模型,负责监听Model
数据变化并更新视图,处理用户交互Model
和View
是通过ViewModel
,Model
的数据变化会触发View
的更新,View
的交互操作也会使Model
的数据发生改变。只需要针对数据进行维护操作,数据的自动同步不需要通过操作dom
实现。
Vue指令
内置指令
指令 | 作用 | 期望数值类型 |
---|---|---|
v-text | 更新元素文本内容 | string |
v-html | 更新元素的innerHTML |
string |
v-show | 条件渲染。根据表达式的真假值,控制元素的显示或隐藏 | any |
v-if | 条件渲染。根据表达式的值的真假条件选择是否渲染元素这个节点 | any |
v-else | 条件渲染。根据v-if 的相反条件进行元素渲染 |
any |
v-else-if | 条件渲染。做v-if 的链式调用 |
any |
v-for | 列表渲染。对数据进行遍历渲染,最好提供key 值 |
Array / Object / number / string |
v-on | 事件处理。绑定事件监听器,事件类型由参数指定,表达式可以是方法名或内联语句。 | Function / Inline Statement / Object |
v-bind | 动态绑定。动态绑定一个或多个特性,或一个组件prop 到表达式 |
any (with argument) / Object (without argument) |
v-model | 表单绑定。在表单或组件是上创建双向绑定 | 随表单控件类型变化 |
v-pre | 跳过该元素和它的子元素的编译过程 | |
v-cloak | 设置 [v-cloak] { display: none } 可以在渲染时延后加载Vue 实例,避免闪现 |
|
v-once | 元素和组件只渲染一次,重新渲染,元素/组件及其所有的子节点将被视为静态内容并跳过 |
自定义指令
不是刚需,和生命周期有很大关系,可见五个生命周期钩子。
bind
inserted
update
componentUpdated
unbind
Vue响应式原理
Vue
实例化时,遍历访问data
的所有属性,使用Object.defineProperty
将其属性全部转换为getter/setter
进行依赖追踪以便修改属性时进行变更通知,每个组件实例都有相应的 watcher 实例对象,它会在组件渲染的过程中把属性记录为依赖,之后当依赖项的 setter
被调用时,会通知 watcher 重新计算,从而致使它关联的组件得以更新。
Vue双向数据绑定
什么是双向数据绑定
model
的更新会触发view
的更新,view
的更新也会触发model
的更新
什么是单向数据流
model
的更新会触发view
的更新,但是view
的更新不会触发model
的更新
双向绑定 or 单向数据流
Vue
是单向数据流,不是双向绑定Vue
的双向绑定不过是语法糖Object.defineProperty
是用来做响应式更新的,和双向绑定没关系
简单实现一个响应式双向数据绑定
简单实现,有一个子组件输入框,一个按钮,父组件通过props
传值给子组件,当按钮增加时,子组件通过$emit
通知父组件修改相应的props
值。
<div id="app">
<parent></parent>
</div>
<script>
var childNode = {
template:`
<div class = "child">
<div>
<span>子组件数据</span>
<input v-model="childMsg">
<button @click=add>+1</button>
</div>
</div>
`,
data(){
return{
childMsg:0
}
},
methods: {
add(){
this.childMsg++;
this.$emit('update:foo',this.childMsg)
}
}
};
var parentNode = {
template:`
<div class="parent">
<div>
<span>父组件数据:{{msg}}</span>
<child :foo.sync="msg"></child>
</div>
</div>
`,
components:{
'child':childNode
},
data(){
return{
'msg':0
}
}
};
let vm = new Vue({
el:'#app',
components:{
'parent':parentNode
}
})
合理应用计算属性和侦听器
计算属性(computed
)的应用
- 处理数据计算,减少模板中计算逻辑
- 数据缓存。当计算的数据比较多的时候,放在计算属性中,不会在每次渲染界面的重新计算,提高页面性能
- 它必须依赖固定的数据类型(响应式数据),而不是全局数据
侦听器(watch)
- 更加灵活、通用,可以触发一系列的操作
watch
提供一个底层API
,可以执行任何逻辑,如函数节流、Ajax
异步获取数据,操作DOM
,但是不推荐
计算属性和侦听器的应用场景
- 计算属性
computed
能做的,侦听器watch
都能做,反之不行 - 能用计算属性
computed
的尽量不用侦听器watch
Vue的生命周期钩子
钩子 | 调用 | 类型 | 是否在服务端渲染期间调用 |
---|---|---|---|
beforeCreate | Vue 实例初始化之后,数据观察和事件配置之前 |
Function | Yes |
create | 实例创建完成(数据观察/属性和方法运算/事件回调)之后,挂载之前 | Function | Yes |
beforeMount | 挂载开始之前,render 函数首次调用 |
Function | Yes |
mounted | 实例挂载完成之后 | Function | No |
beforeUpdate | DOM 被patch 之前调用进行数据修改 |
Function | No |
updated | 组件 DOM 更新完成,避免在此期间更改状态 | Function | No |
actived | keep-alive 组件激活时 | Function | No |
deactived | keep-alive 组件停用时 | Function | No |
beforeDestroy | 实例销毁之前 | Function | No |
destroyed | 实例销毁 | Function | No |
errorCaptured | 当任何一个来自后代组件的错误时被捕获时 收到三个参数:错误对象、发生错误的组件实例,和一个包含错误在何处被捕获信息的字符串 返回 false,以阻止该错误继续向上冒泡 |
Function | No |
函数式挂件
一般用于做展示用。
functional:true
- 无状态、无实例、没有
this
上下文、无生命周期
Vue组件
Vue
组件 = Vue
实例 = new Vue(options)
,每个组件就是一个Vue
实例。组件可以是页面中每一个区域板块,也可以是某一个复用业务逻辑,也可以是每一个单页面。
组件的构成
就以上面的双向数据绑定实现为例:
- 属性:
- 自定义属性
props
:组件props
中声明的属性,父组件使用props
定义数据属性,向子组件传递数据 - 原生属性
attrs
:没有声明的属性,默认自动挂载到组件根元素上,设置inheritAttrs
为false
可以关闭自动挂载 - 特殊属性
class
、style
:挂载在组件根元素上,支持字符串、对象、数组等多种语法
- 自定义属性
- 事件
event
:- 普通事件:
@click
、@input
、@change
、@xxx
等事件,通过this.$emit('xxx',...)
触发自定义事件event
向父组件发送消息 - 修饰符事件:
@input.trim
、@click.stop
、@submit.prevent
等,一般用于原生HTML
元素,自定义组件需要自行开发支持
- 普通事件:
- 插槽
slot
:- 普通插槽:
slot
进行组件内容分发,插入子组件内容,简单点就是传递内容的<template slot="xxx">...</template>
、<template v-slot="xxx">...</template>
- 作用域插槽:需要根据子组件的某些值来做动态处理,可以简单理解为返回组件的函数
<template slot="xxx" slot-scope="props">...</template>
、<template v-slot:xxx="props">...</template>
- 普通插槽:
组件通信
- 父子组件通信:父组件使用
props
向子组件通信,子组件使用$emit
向父组件传递消息 - 非父子组件通信:父组件可以使用
v-on
监听子组件的任何事件,子组件使用$emit
传入事件,这样父组件就会收到事件并更新 - 跨级组件通信:使用
Vuex
比较好管理
组件更新
组件的更新都是由数据驱动的,没有特殊情况,任何更改DOM
的行为都是在作死。
数据来源(单向)
包含三个部分:
- 来自父组件的属性
props
- 来自组件自身的状态
data
- 来自状态管理器,如
vuex vue.observable
注意
状态和属性的改变未必会触发组件更新
高级特性provide/inject
一般用于底层组件通信。底层组件通信,不仅属性要层层传递,事件也要层次冒泡,这是很耗性能的。
Vue-router路由
Vue Router 是 Vue.js 官方的路由管理器。它和 Vue.js 的核心深度集成,让构建单页面应用变得易如反掌。包含的功能有:
- 嵌套的路由/视图表
- 模块化的、基于组件的路由配置
- 路由参数、查询、通配符
- 基于 Vue.js 过渡系统的视图过渡效果
- 导航控制
- 带有自动激活的 CSS class 的链接
- HTML5 历史模式或 hash 模式,在 IE9 中自动降级
- 自定义的滚动条行为
下面是一个简单路由的实现:
<div id="app" class="demo">
<h1>Hello App!</h1>
<p>
<!-- 通过router-link导航 -->
<!-- 通过传入'to '属性指定链接-->
<!-- <router-link> 默认会被渲染成一个 `<a>` 标签-->
<router-link to="/foo">go to Foo</router-link>
<router-link to="/bar">go to Bar</router-link>
</p>
<!-- 路由出口 -->
<!-- 路由匹配到的组件将渲染在这里 -->
<router-view></router-view>
</div>
<!--
0. 如果使用模块化机制编程,导入Vue和VueRouter,要调用 Vue.use(VueRouter)
1. 定义 (路由) 组件。
2.定义路由
-->
<script>
//1. 定义 (路由) 组件。
const Foo = {template:'<div>foo</div>'};
const Bar = {template:'<div>bar</div>'};
//2.定义路由
//每个路由应该映射一个组件。其中component可以是通过Vue.extend()创建的组件构造器
//或者只是一个组件配置对象
const routes = [
{path:'/foo',component:Foo},
{path:'/bar',component:Bar}
] //3.创建router实例,然后传‘routes’配置
const router = new VueRouter({
routes//(缩写)相当于routes:routes
}) //4.创建和挂载根实例
//要记得通过router配置参数注入路由,从而让整个应用都有路由功能 const app = new Vue({
router
}).$mount('#app');
Vue针对性笔记的更多相关文章
- Vue学习笔记-2
前言 本文非vue教程,仅为学习vue过程中的个人理解与笔记,有说的不正确的地方欢迎指正讨论 1.computed计算属性函数中不能使用vm变量 在计算属性的函数中,不能使用Vue构造函数返回的vm变 ...
- Vue学习笔记-1
前言 本文不是Vue.js的教程,只是一边看官网Vue的教程文档一边记录并总结学习过程中遇到的一些问题和思考的笔记. 1.vue和avalon一样,都不支持VM初始时不存在的属性 而在Angular里 ...
- Vue学习笔记-Vue基础入门
此篇文章是本人在学习Vue是做的部分笔记的一个整理,内容不是很全面,希望能对阅读文章的同学有点帮助. 什么是Vue? Vue.js (读音 /vjuː/,类似于 view) 是一套构建用户界面的渐进式 ...
- Vue学习笔记三:v-bind,v-on的使用
目录 v-bind:绑定属性值,内容相当于js,缩写: v-on:绑定方法,缩写@ 总结 v-bind:绑定属性值,内容相当于js,缩写: 我添加了一个input标签,如下 <input typ ...
- vue 学习笔记(二)
最近公司赶项目,一直也没时间看 vue,之前看下的都快忘得差不多了.哈哈哈,来一起回顾一下vue 学习笔记(一)后,继续向下看嘛. #表单输入绑定 基础用法 v-model 会忽略所有表单元素的 va ...
- vue 自学笔记记录
vue 自学笔记(一): 知识内容: 安装vue ,创建vue实例,安装第一个组件,单项数据流 https://www.cnblogs.com/baili-luoyun/p/10763163.htm ...
- vue学习笔记之:为何data是一个方法
vue学习笔记之:为何data是一个方法 在vue开发中,我们可以发现,data中的属性值是在function中return出来的.可为何data必须是一个函数呢?我们先看官方的解释: 当一个组件被定 ...
- Vue:实践学习笔记(3)——组件使用
Vue:实践学习笔记(3)——组件使用 全局注册 1.注册组件 Vue.component('my-component',{ //选项 }) 说明:my-component就是注册的组件自定义的标签名 ...
- Vue:实践学习笔记(1)——快速使用
Vue:实践学习笔记(1)——快速使用 Vue基础知识 0.引入Vue 官方地址:Vue的官方下载地址 Vue推荐博客:keepfool 在你的程序中快速引入Vue: <!-- 开发环境版本,包 ...
随机推荐
- CSS3制作上下跳动动画箭头效果
动画效果如下: 代码如下: 1 <!DOCTYPE html> 2 <html> 3 <head> 4 <meta charset="utf-8&q ...
- 《全栈营销之如何制作个人博客》之一:用什么开发语言和CMS系统
现在的互联网,已经不再是初级互联时代,是需要全方位营销,自建粉丝池的时代,云码素材从提出全栈营销,到实践分析,总结出全栈营销第一步,先制作一个个人博客是最好的开始.今天开始就跟我一起学习如何制作一个精 ...
- [置顶]生鲜配送管理系统_升鲜宝V2.0 销售订单汇总_采购任务分配功能_操作说明
做好生鲜供应链系统,要注意三个方面,1.分拣 2 采购 3 库存,市面上做的比较成熟的功能,还是分拣这一块(按客户分拣.按订单分拣.按商品分类分拣.按商品分拣.按线路分拣.客户自由组合分拣)[下篇文 ...
- kkkK的随笔
自我介绍 学号:211606310 姓名:柯伟敏 爱好:篮球,足球 最爱的菜:4堂的饺子 最想说的话:一切都是最好的安排 初入大学 -------------------- 选择 选择软件工程这个专业 ...
- 记MVC学习过程中一次传参到View时遇到的错误
在跟着 <PRO ASP.NET MVC5>一书进行第七章的练习的时候遇到了以上问题, 当遇到此类问题的时候应该先检查方法传输和其视图接受的数据类型是否一致, 大多时候都是因为两者数据类型 ...
- UOJ #269. 【清华集训2016】如何优雅地求和
UOJ #269. [清华集训2016]如何优雅地求和 题目链接 给定一个\(m\)次多项式\(f(x)\)的\(m+1\)个点值:\(f(0)\)到\(f(m)\). 然后求: \[ Q(f,n,x ...
- LinkedList类 和ArrayList类
1)LinkedList类 LinkedList实现了List接口,允许null元素.此外LinkedList提供额外的get,remove,insert方法在 LinkedList的首部或尾部.这 ...
- nginx 常见正则匹配符号表示
1.^: 匹配字符串的开始位置: 2. $:匹配字符串的结束位置: 3..*: .匹配任意字符,*匹配数量0到正无穷: 4.\. 斜杠用来转义,\.匹配 . 特殊使用方法,记住记性了: 5.(值1|值 ...
- 前端开发 JavaScript 规范文档
一,规范目的 为提高团队协作效率,便于前端后期优化维护,输出高质量的文档. 二.基本准则 符合web标准,结构表现行为分离,兼容性优良.页面性能方面,代码要求简洁明了有序, 尽可能的减小服务器负载,保 ...
- 安装Cnario提示.Net 3.5安装错误, 检查Windows系统更新提示无法检查到更新, 安装.Net 3.5提示"Windows无法完成请求的更改, 错误代码:0x800F081F"
症状: Windows检查系统更新时提示无法完成, 尝试安装.Net 3.5等组件时都无法完成, 错误代码: 0x800F081F 原因: 可能时设置了禁止Windows自动更新, 需要重新打开 解决 ...