vue3:25—其他API

目录

1、shallowRef和shallowReactive

2、readonly与shallowReadonly

readonly

shallowReadonly

3、toRaw和markRaw

toRaw

markRaw 

4、customRef 


1、shallowRef和shallowReactive

shallowRef

  • 1.作用:创建一个响应式数据,但只对顶层属性进行响应式处理。
  • 2.用法:let myVar =shallowRef(initialValue);
  • 3.特点:只跟踪引用值的变化,不关心值内部的属性变化。)

shallowReactive

  • 作用:创建一个浅层响应式对象,只会使对象的最顶层属性变成响应式的,对象内部的嵌套属性则不会变成响应式的
  • 用法:const myObj=shallowReactive({...});
  • 3.特点:对象的顶层属性是响应式的,但嵌套对象的属性不是

shallowRef::只能修改第一层数据

下图代码中。changeName和changeAge不起作用

shallowReactive:只能修改第一层数据

2、readonly与shallowReadonly

readonly

  • 作用:用于创建一个对象的深只读副本,
  • 用法:
const original=reactive({...});

const readOnlyCopy=readonly(original):

  • 特点:

       对象的所有嵌套属性都将变为只读。中
       任何尝试修改这个对象的操作都会被阻止(在开发模式下,还会在控制台中发出警告)中

  • 应用场景:

        创建不可变的状态快照。
        保护全局状态或配置不被修改。


shallowReadonly

1.作用:与 readonly 类似,但只作用于对象的顶层属性,
用法: 

。。。。

3、toRaw和markRaw

toRaw

1、作用:用于获取一个响应式对象的原始对象, toRaw 返回的对象不再是响应式的,不会触发视图更新。【raw:未经加工的】

官网描述:这是一个可以用于临时读取而不引起代理访问/跟踪开销,或是写入而不触发更改的特殊方法。不建议保存对原始对象的持久引用,请谨慎使用。
何时使用?——在需要将响应式对象传递给非 Vue 的库或外部系统时,使用 toRaw 可以确保它们收到的是普通对象

2、具体编码:

markRaw 

作用:标记一个对象,使其永远不会变成响应式的。


例如使用 mockjs 时,为了防止误把 mockjs 变为响应式对象,可以使用 markRaw 去标记 mockjs

 

4、customRef 

封装成hooks   :useMsgRef.ts

import { customRef } from "vue"
export default function (initValue: string, delay: number) {
    //track:跟踪  trigger:触发
  const msg = customRef((track, trigger) => {
    return {
      get() {
        track()// 告诉Vue数据msg很重要,要对msg持续关注,一旦msg变化就去更新
        return initValue
      },
      set(value) {
        const timer = setTimeout(() => {
          initValue = value
          trigger()//通知Vue数据msg变化了
          clearTimeout(timer)
        }, delay);
      }
    }
  })
  return {msg}
}

使用

  • 3
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Vue 3是一种流行的JavaScript框架,用于构建用户界面。它是Vue.js的最新版本,带来了许多新的特性和改进,以提高开发者的效率和应用程序的性能。 以下是Vue 3的一些主要特点和改进: 1. 更快的渲染性能:Vue 3引入了一个全新的响应式系统,使用Proxy代理对象来跟踪数据的变化。这个新系统比Vue 2中使用的Object.defineProperty更高效,可以提供更快的渲染性能。 2. 更小的包大小:Vue 3通过使用Tree-shaking技术和优化打包算法,可以生成更小的包大小,减少应用程序的加载时间。 3. Composition APIVue 3引入了Composition API,这是一种基于函数的API风格,可以更好地组织和重用组件逻辑。它使得组件更易于理解和维护,并且可以更好地支持TypeScript类型推断。 4. 更好的TypeScript支持:Vue 3对TypeScript的支持得到了改进,可以提供更好的类型推断和类型检查,使得开发过程更加可靠和高效。 5. 更好的逻辑复用:Composition API使得逻辑复用更加容易。开发者可以将逻辑抽象为自定义的函数,并在多个组件中进行复用,提高了代码的可维护性和重用性。 6. 更好的错误处理:Vue 3引入了错误边界(Error Boundary)的概念,可以更好地捕获和处理组件中的错误,避免整个应用程序崩溃。 7. 更好的TypeScript支持:Vue 3对TypeScript的支持得到了改进,可以提供更好的类型推断和类型检查,使得开发过程更加可靠和高效。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值