vue3学习笔记

1.vue3是由ts重写的,由proxy实现的响应式数据

2.优点

1,性能比vue快了1.2~2倍。

a.diff算法中与上次节点比较时只比较带有静态标记的。

b.静态提升

对于不更新的元素会做静态提升,只会被创建一次,下次渲染时直接复用。

c,监听器缓存

onclik会被视为动态绑定,所以每次都会去追踪它的变化,但是由于是同一个函数,所以没有追踪变化,而是缓存起来直接使用。

b,ssr渲染

当有大量静态内容时,这些内容会被当做纯字符推进buffer里面,即使存在动态绑定,也会通过模板插值嵌入进去,这样会比虚拟dom渲染快上很多,当这些金泰内容大到一定量级,会用_createStaticVNode方法在客服端生成一个static node,这些静态node会被直接innerHtml。

只比较带有静态标记的,而vue2是全量比较

2,支持按需导入体积比vue2更小

3,组合api(类似于react hook)

4,更好的ts支持

5,暴露了自定义渲染api

6,更先进的组件

3.setup

1,setup执行时机是在beforeCreate之后,create之前,因此它没有data数据和$vm对象,所以在setup中是不能使用data的数据。

2,因为没有this,所以vue为了避免我们错误使用,把this定义为undifine。

3,setup中也没有methods。

4.setup只能是同步的函数,不能是异步的

4.reactive

1,reactive必须传递对象,而且只能是数组或者自定义对象,像Date这些内置对象是无法让数据响应式的。

5.ref

1,ref本质上就是reactive,即使他传入的不是对象,也会转化为{value:值}的形式。

2,在template中不需要使用.value,在script标签中需要使用.value。

6.递归监听

1,ref,reactive默认是递归监听的,把对象每一层都包装成了一个proxy对象,所以很耗费性能。

7.非递归监听

1,shallowReactive,只监听第一层的变化。

2,sahllowRef,只监听value的变化,可以通过tiggerRef()来控制变化,注意只有ref有tiggerRef,而没有triggerReacive,shallowRef本质是sahllowReactive。

3,一般情况下使用递归监听,只有当监听的数据量比较大时才使用非递归监听。

8.toRow

1,拿到reactive的原始数据,原始数据是reactive的引用,修改原始数据会改变reactive,但是不会触发视图的更新,对于不需要视图更新的操作极大的提高了性能。

2,拿ref中的原始数据需要拿.value中的数据

9.markRow

1,使一个数据永远不会被追踪

10.toRef

1.使数据与响应式数据关联起来,并且不触发视图的更新

2.接受2个参数:对象和属性,使用.value获取

11.toRefs

1,接受一个对象,把对象所有属性都toRef,接受一个对象,使用.属性.value获取

12.custemRef

为什么要自定义ref?

setup不支持async await,为了避免在setup中出现大量回调函数,所以可以把回调函数放到custemref中

13,获取元素

在setup中let box=ref(null),然后暴露出去,在template中ref=box,然后在onMounted中获取。

14.readonly,shallowReadonly,isReadonly

1,readonly:创建一个只读的数据,并且是递归只读

2,shallowReadonly:创建一个只读数据,不是递归只读,只有第一层是只读的

3,判断是否是只读的

4,readonly与const的区别:

const是赋值保护,不能给变量重新赋值,readonly是属性保护,不能给属性重新赋值

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值