Vue 重点 必须要记住的

基础知识:

  • vue的生命周期: beforeCreate/created、 beforeMount/mounted、 beforeUpdate/updated、 beforeDestory/destoryed
  • vue常用指令: v-for、 v-bind(缩写形式 :prop)、 v-on(缩写形式 @click=’sss‘)、 v-if/v-else/v-else-if、 v-model、 v-once、 v-html、 v-show...
  • vue自定义组件: Vue.component(‘componentName‘,{ props:[‘p1’,’p2’], template: ‘<li>{{ p1 }}</li>‘})
  • vue常用实例方法和属性: data/$data、 methods/$methods、 $el、 computed(计算属性)、 $watch、 $set、 $event、 $emit...
  • 如果需要更新的属性需要缓存,则使用计算属性的方式,否则可以使用 methods里的方法来更新属性( methods里的方法每次重新渲染都会执行)
  • 计算属性默认提供了 getter,你还可以给它设置 setter
  • 当你数据变化是异步或者开销较大时,可以使用 watch侦听器来响应数据的变化
  • v-bind:class的值可以是一个对象,可实现类似 react中 classnames模块的功能
  • 自定义组件上的 class会被渲染拼接到 template的根节点的 class属性上(自定义组件上可使用 v-bind:class来做class的判断显示逻辑)
  • v-bind:style可以用来绑定内联样式,这个内联样式的值可以由一个对象来定义(类似css in js的模式),且可以被定义为数组(多个样式对象)
  • v-bind:style可以使用多重值的形式: <div:style=“display:[‘-webkit-box’,’-ms-flexbox’,‘flex‘]"></div>
  • v-if/v-else/v-else-if的时候,可以用key来管理可复用的元素
  • v-if是’真正’的渲染,它会确保在切换条件过程中条件块内的元素的事件监听器和子组件适时的销毁和重建
  • v-if是惰性的,初始为假,什么也不做,直到为真的时候才渲染元素
  • v-show总是渲染元素,只是简单的进行切换
  • v-if的切换开销大, v-show则是初始渲染开销大,频繁切换使用 v-show,运行时经常改变则使用 v-if
  • v-if和 v-for一起使用时, v-for的优先级更高
  • v-for可遍历数组,第二个参数是索引
  • v-for可遍历对象,第二个参数是 key,第三个参数是索引
  • v-for和 <template>搭配可减少渲染次数
  • v-for和自定义组件使用时,需要使用 props来传递值
  • 尽可能的为遍历子元素加上 key,获得渲染优化
  • 数组变异方法: push/pop/unshift/shift/splice/sort/reverse改变原始数组
  • 数组非变异方法: filter/concat/slice 不改变原始数组,总是返回新数组
  • Vue不能检测到数组索引赋值(使用 vm.$set解决)和修改 length长度赋值(使用 splice解决)的情况
  • Vue不能检测对象属性的添加和删除(使用 vm.$set或 Object.assign)
  • is=“todo-item”这种属性的写法比较适合DOM模板
  • 事件修饰符,它们可串联使用: .stop、 .prevent、 .capture、 .self、 .once、 .passive(尤其适合移动端)
  • .passive不用同时和 .prevent使用,后者会被忽略
  • 按键修饰符: .enter、 .tab、 .delete、 .esc、 .space、 .up、 .down、 .left、 .right
  • 系统按键修饰符: .ctrl、 .alt、 .shift、 .meta(?|?|◆)、 .exact(允许精确控制系统修饰符组合键触发)
  • 鼠标修饰符: .left、 .right、 .middle
  • v-model会忽略表单元素的 value、 checked、 selected,仅仅使用实例中的数据作为数据源
  • 表单事件修饰符: .lazy、 .number、 .trim
  • 组件是可复用的vue实例,具有vue实例大多数属性和方法
  • 组件可复用,每个组件有独立的空间
  • 组件上的data必须是一个函数,这样做避免影响了其他组件
  • 通过 Vue.component()全局注册的组件可在其被注册后的任何通过 newVue()创建的实例所使用,包含其组件树中的所有组件
  • 通过插槽 <slot>分发内容(其实就是类似于react的children)
  • 动态组件 <component>配合属性 is来实现
  • 解析DOM模板时需要注意下可能会有不生效的情况,需要使用is来传递组件

Vue组件

  • 全局注册/局部注册
  • 局部注册组件在子组件中不可用
  • 全局注册的行为必须在根Vue实例创建之前发生
  • camelCase的属性可以在组件中使用 kebab-case
  • 可以以对象的模式指定每一个 props属性的类型
  • 父级 props的更新会向下流动,反之则不行
  • 由于JavaScript对象和数组是引用传入的,所以当子组件对props的改变将会影响到父组件
  • props类型校验可以是原生构造对象的中的任意一个,也可以自定义检验类型,通过 instanceof检查
  • 对于绝大多数特性来说,外部传入的值会替换掉组件内部设置好的值,如input的type属性,但有的属性则是会进行合并,如class
  • inhertAttrs:false设置不希望根元素继承特性,可以使用 $attrs属性来设置继承的目标元素
  • v-on在设置事件监听器时,会把事件名全部转换成小写,推荐始终使用 kebab-case的事件名
  • v-model可以使用自定义组件中的 model属性自定义
  • 父组件模板的所有东西都会在父级作用域内编译,子组件的所有内容都会在子组件作用域内编译
  • 插槽( <slot></slot>)/具名插槽( <slotname=“header"></slot>)/作用域插槽( slot/slot-scope)
  • <keep-alive>组件可用来缓存被切换后隐藏的组件的状态
  • $root访问根实例, $parent访问父组件实例(不推荐)
  • 父组件访问子组件,使用 $refs属性来获取设置了 ref属性的子组件
  • provide属性允许我们指定要分享给后代组件使用的方法,然后后代组件使用 inject属性来获得祖先组件分享的方法(依赖注入)
  • 事件侦听器( $emit派发的事件)
    • v-on 指令侦听
    • $on 侦听一个事件
    • $once 一次性侦听一个事件
    • $off 停止侦听一个事件
  • 慎用递归组件
  • 尽量避免组件的循环引用
  • 优先使用 template来定义模板,而不是 inline-template
  • $forceUpdate来强制更新view
  • 组件包含大量静态内容时,可使用 v-once来标记,缓存静态内容

过渡 & 动画

  • transition组件控制过渡动画,可以给任何元素和组件添加进入/离开过渡
  • 当插入或删除 transition中的元素时,vue会做如下处理
    • 自动嗅探元素是否使用了css过渡和动画,适当时机添加/删除类名
    • 元素的钩子函数会在适当时机被调用
    • 元素既没有钩子函数也没有css动画,插入和删除操作在下一帧立即执行(浏览器逐帧动画机制)
  • 过渡的类名
    • v-enter/v-enter-active/v-enter-to
    • v-leave/v-leave-active/v-leave-to
  • css动画用法同css过渡,区别是类名 v-enter不会在DOM插入后立即删除,而是在 animationend事件触发时删除
  • 自定义过渡类名,使用以下属性指定:
    • enter-class/enter-active-class/enter-to-class
    • leave-class/leave-active-class/leave-to-class
    • 自定义类名优先级高于普通的类名
  • 使用 type属性设置 transition或 animation来申明vue使用的动画类型
  • transition组件上使用 duration来设置动画执行的时间
  • 可以使用钩子函数
    • beforeEnter/enter/afterEnter/enterCancelled
    • beforeLeave/leave/afterLeave/leaveCancelled
    • 钩子函数使用 v-on指令绑定
    • 钩子和结合过渡和动画使用,也可以单独使用
    • 在 enter/leave中,必须使用 done()来进行回调,否则会同步调用,过渡或动画会立即完成
    • 对于纯使用JavaScript来进行的动画,推荐使用 v-bind:css=“false”来取消css的检测,减少css的影响
  • 可使用 apear设置初始渲染的过渡
    • apear/apear-active/apear-to
    • beforeApear/apear/afterApear/apearCancelled
  • 多元素过渡,设置唯一 key
  • 过渡模式:
    • In-out 新元素先过渡,完成后当前元素过渡离开
    • out-in 当前元素先过渡,完成后新元素过渡进入
    • 默认行为:进入和离开同时发生
  • 多个组件过渡使用动态组件实现
  • 列表过渡 <transition-group>
    • 以真实元素呈现,默认为 <span>,可使用tag更改呈现标签
    • 过渡模式不可用
    • 内部需要唯一 key
  • 列表排序过渡,使用的是 FLIP动画,使用类名 v-move来定义class

可复用性 & 组合

  • mixins混入属性发生冲突时,以组件数据优先(一层属性深度浅合并)
  • mixins混入方法发生冲突时,会将函数合并为一个数组,优先执行混入方法,其次执行组件方法
  • Vue.extend策略和 mixins相同
  • 慎用全局混入
  • 合并策略可以自定义(参考 vuex的具体实现: Vue.config.optionMergeStrategies
  • 全局自定义指令: Vue.directive()
  • 局部自定义指令:属性 directives,类型为 Object
  • 钩子函数
    • bind 指令第一次绑定到元素时调用,只执行一次,可用于一次性初始化设置
    • inserted 元素插入父节点时调用
    • update 所有VNode更新时调用,可能发生在子VNode之前
    • componentUpdated 指令所在组件在VNode和其子VNode更新后调用
    • unbind 指令与元素解绑时调用
  • 钩子函数都会被传入以下参数:
    • el 指令绑定元素,可操作DOM
    • binding 指令描述对象
    • vnode Vue生成的虚拟节点
    • oldVnode 上一个 Vnode,仅在 update和 componentUpdated中使用
  • 指令接受所有合法的JavaScript表达式

渲染函数 & JSX

  • render函数接受 createElement方法作为参数
  • createElement方法的作用是创建一个虚拟节点(VNode)
  • createElement参数比较复杂,参照官网:参数
  • 组件树中的 VNodes必须唯一
  • render中的 v-if/v-for可以使用 if/else和 map重写
  • 插槽使用 this.$slot.default访问,作用域插槽使用 this.$scopeSlots.default访问和设置
  • 可以使用插件 babel-plugin-transform-vue-jsx支持JSX语法
  • 将h作为 createElement的别名是Vue生态的一个惯例,也是JSX要求的
  • 函数式组件 关键词:functional
  • 函数式组件渲染开销低,但相应的,它不会出现在Vue devtools的组件树里边
  • 函数式组件要求你自己实现同名特性的替换与智能合并
  • Vue的模板实际编译成了 render方法实现的 VNode,可以使用 Vue.compile()方法来输出编译结果

插件

  • 插件会为vue提供全局的功能,包括但不限于以下几种:
    • 添加全局的属性或方法,如vue-custom-element
    • 添加全局的资源(指令、过滤器、过渡等),如:vue-touch
    • 通过全局 mixins添加一些组件选项,如:vue-router
    • 添加Vue实例方法,通过添加到 Vue.prototype上实现
    • 一个独立的库,同时有自己的API,又实现以上部分功能,如:vue-router
  • Vue插件有一个公开的方法 install,第一个参数是Vue构造器,第二个参数是一个可选对象
  • 插件的使用通过全局方法 Vue.use(MyPlugin)使用,只会注册一次插件
  • 在CommonJS中,应该始终显式的调用 Vue.use方法
  • 社区插件列表awesome-vue

过滤器

  • {{msg|filter}}
  • <divv-bind=“msg|filter"></div>
  • 全局过滤器使用Vue.filter()创建
  • 局部过滤器使用对象属性filters创建
  • 过滤器函数总是接收表达式的值作为第一个参数,过滤器可以有多个,值依次向后传递
  • 过滤器可以接收额外的参数

构建 & 部署

  • <script>标签引入 [vue.min.js](https://vuejs.org/js/vue.min.js)
  • 使用 vue-cli
    • webpack + vue-loader
    • browserify + vueify
    • rollup + rollup-plugin-vue
  • 利用钩子函数 Vue.config.errorHandler定义配置来跟踪运行时错误,可以搭配 [Sentry](https://sentry.io/)使用(集成配置)
  • 单文件组件( .vue文件)

原文地址:https://www.cnblogs.com/tongshuangxiong/p/9668189.html

时间: 2024-10-11 23:05:33

Vue 重点 必须要记住的的相关文章

解析vue重点问题

使用vue的时候经常会遇到一些问题,其实仔细阅读查阅官方文档,就会发现文档中已提到一些格外需要注意的点; 为了深入的理解官方文档中对这些问题的解释,查阅了一些资料,再加上自己的理解,整理了一些常见的问题 1.组件三种挂载方式 自动挂载 var app3 = new Vue({ el: '#app-3', data: { seen: true } }) 手动挂载 // 可以实现延迟按需挂载 <div id="app"> {{name}} </div> <bu

5种处理Vue异常的方法

原文: Handling Errors in Vue.js 译者: Fundebug 本文采用意译,版权归原作者所有 去年一整年,我都在使用最爱的-Vue.js- 来做项目.最近突然意识到,我竟然从来没有认真去处理异常.我可以自恋地说:"我写的代码是完美的,没有BUG." 我相信大家都明白这是迷之自信.最近,我花了不少时间研究了Vue中处理异常的各种技巧,在此想把我学到的分享给大家. 错误大全 为了测试各种异常处理技巧,我故意触发三种类型的错误. 第一种:引用一个不能存在的变量: &l

Chromium的GPU进程启动过程分析

Chromium除了有Browser进程和Render进程,还有GPU进程.GPU进程负责Chromium的GPU操作,例如Render进程通过GPU进程离屏渲染网页,Browser进程也是通过GPU进程将离屏渲染好的网页显示在屏幕上.Chromium之所以将GPU操作运行在独立进程中,是考虑到稳定性问题.毕竟GPU操作是硬件相关操作,硬件的差异性会引发一定的不稳性.本文分析GPU进程的启动过程. 老罗的新浪微博:http://weibo.com/shengyangluo,欢迎关注! GPU进程

C/C++函数指针(typedef简化定义)

学习要点:        1,函数地址的一般定义和typedef简化定义;        2,函数地址的获取;        3,A函数地址作为B函数参数的传递;    函数存放在内存的代码区域内,它们同样有地址.如果我们有一个int test(int a)的函数,那么,它的地址就是函数的名字,这一点如同数组一样,数组的名字就是数组的起始地址.    定义一个指向函数的指针用如下的形式,以上面的test()为例:    int (*fp)(int a);//这里就定义了一个指向函数(这个函数的参

猫猫学iOS(五十五)多线程网络之图片下载框架之SDWebImage

猫猫分享,必须精品 原创文章,欢迎转载.转载请注明:翟乃玉的博客 地址:http://blog.csdn.net/u013357243?viewmode=contents 效果: 代码: - (NSArray *)apps { if (!_apps) { NSArray *dictArray = [NSArray arrayWithContentsOfFile:[[NSBundle mainBundle] pathForResource:@"apps.plist" ofType:nil

GitHub的实践

GitHub的实践 2017-05-08,晴,来小米已经一周的时间了,感谢领导能给我一周的时间来熟悉 ubuntu.spring boot.maven.docker.github .大家会问,这些不都是你应该掌握的吗?Sorry,其实我是从 .net 刚转 java 的.其实说转不太符合我的初衷,我想表达的是,我其实是扩充了一下我的技术线.C# 我个人认为是一门非常不错的语言,.net 的框架配合vs真的是极大的解放了生产力.不信的话你来配配java的相关环境,以及ubuntu的操作系统,各种配

CSS开发中的10个不要

自我进入这个行业,我就发现开发人员一直在努力征服CSS. 理由也很充分,开发人员是用逻辑思考的生物.添加一个DIV元素导致所有代码都不得不往下移一行,而另一个DIV“浮”到左侧,感觉没有任何意义. 你也一定听到过开发人员的抱怨: “我们只需要向左边移动五个像素,但是…天哪!为什么整个都向下移动了一行.到底是哪里错了?!?!?!” 所以,我们今天就来聊一聊CSS中的十大错误的做法. 根据我作为开发人员使用CSS的经验,下面是我的十个“不要”. 1.不要滥用类在有意义的地方使用ID而不要使用类.这是

你真的懂线程同步么?

前言:学进程时,学习的重点应该进程间通信,而学习线程时,重点就应该是线程同步了.想过为什么?fork创建子进程之后,子进程有自己的独立地址空间和PCB,想和父进程或其它进程通信,就需要各种通信方式,例如无名管道(管道,我习惯这么叫无名管道).有名管道(命名管道).信号.消息队列.信号量.共享内存等:而pthread_create创建子线程之后,子线程没有独立的地址空间,大部分数据都是共享的,如果同时访问数据,就是造成混乱,所以要控制,就是线程同步了. 一.同步概念 为什么要特意说一下同步概念呢?

数组加强

数组的概念 概念:数组的本质是存储.管理和操作一组变量属于复合类型的一种. 键值对的概念: $arr = array('id'=>1,'name'=>'duke','sex'=>'妖'); 每个数组可以有多个值,多个值之间用逗号隔开,每个逗号内的数据我们称为一个单元,每个单元都 是有键(下标)=>值 ,也就是键值对组成,如果不写下标(键)默认会使用整数作为下标,每个单元的值 必须有下标通过下标来定位每个值在数组中的位置,每个单元只能有一种类型的下标.索引(整数)或 者关联(字符串)