vue基础知识点

本文深入探讨Vue.js的关键特性,包括生命周期、指令、组件、数据绑定及事件处理。覆盖了从基础到进阶的主题,如计算属性、watch侦听器、v-if与v-show的区别,以及性能优化技巧。

基础知识:
在这里插入图片描述

  • 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: ‘
  • {{ p1 }}
  • ’})

vue常用实例方法和属性: data/data、methods/data、 methods/datamethods/methods、 $el、 computed(计算属性)、 $watch、 $set、 $event、 $emit…
如果需要更新的属性需要缓存,则使用计算属性的方式,否则可以使用 methods里的方法来更新属性( methods里的方法每次重新渲染都会执行)

  1. 计算属性默认提供了 getter,你还可以给它设置 setter
  2. 当你数据变化是异步或者开销较大时,可以使用 watch侦听器来响应数据的变化 v-bind:class的值可以是一个对象,可实现类似
    react中 classnames模块的功能 自定义组件上的 class会被渲染拼接到 template的根节点的
    class属性上(自定义组件上可使用 v-bind:class来做class的判断显示逻辑)
  3. v-bind:style可以用来绑定内联样式,这个内联样式的值可以由一个对象来定义(类似css in
    js的模式),且可以被定义为数组(多个样式对象)
  4. v-bind:style可以使用多重值的形式:
    div:style=“display:[‘-webkit-box’,’-ms-flexbox’,‘flex’]"
  5. v-if/v-else/v-else-if的时候,可以用key来管理可复用的元素
  6. v-if是’真正’的渲染,它会确保在切换条件过程中条件块内的元素的事件监听器和子组件适时的销毁和重建
  7. v-if是惰性的,初始为假,什么也不做,直到为真的时候才渲染元素
  8. v-show总是渲染元素,只是简单的进行切换
  9. v-if的切换开销大, v-show则是初始渲染开销大,频繁切换使用 v-show,运行时经常改变则使用 v-if
  10. v-if和 v-for一起使用时, v-for的优先级更高
  11. v-for可遍历数组,第二个参数是索引
  12. v-for可遍历对象,第二个参数是 key,第三个参数是索引
  13. v-for和 搭配可减少渲染次数
  14. v-for和自定义组件使用时,需要使用 props来传递值
  15. 尽可能的为遍历子元素加上 key,获得渲染优化
  16. 数组变异方法: push/pop/unshift/shift/splice/sort/reverse改变原始数组
  17. 数组非变异方法: filter/concat/slice 不改变原始数组,总是返回新数组
  18. Vue不能检测到数组索引赋值(使用 vm.$set解决)和修改 length长度赋值(使用 splice解决)的情况
  19. Vue不能检测对象属性的添加和删除(使用 vm.$set或 Object.assign)
  20. is=“todo-item”这种属性的写法比较适合DOM模板
  21. 事件修饰符,它们可串联使用: .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()全局注册的组件可在其被注册后的任何通过
  22. newVue()创建的实例所使用,包含其组件树中的所有组件 通过插槽
  23. 分发内容(其实就是类似于react的children) 动态组件 配合属性 is来实现
  24. 解析DOM模板时需要注意下可能会有不生效的情况,需要使用is来传递组件
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值