返回顶部
首页 > 资讯 > 前端开发 > JavaScript >深入理解Vue3里的EffectScope
  • 875
分享到

深入理解Vue3里的EffectScope

Vue3EffectScope 2022-11-13 14:11:09 875人浏览 安东尼
摘要

Vue 3.2 版本引入了新的 Effect scope api,使用 effectScope 创建一个 effect 作用域,可以捕获其中所创建的响应式副作用 (即计算属性和侦听器

Vue 3.2 版本引入了新的 Effect scope api,使用 effectScope 创建一个 effect 作用域,可以捕获其中所创建的响应式副作用 (即计算属性和侦听器),这样捕获到的副作用可以一起处理。使用 getCurrentScope 返回当前活跃的 effect 作用域。使用 onScopeDispose 在当前活跃的 effect 作用域上注册一个处理回调函数。当相关的 effect 作用域停止时会调用这个回调函数。

const scope = effectScope()

scope.run(() => {
  const doubled = computed(() => counter.value * 2)

  watch(doubled, () => console.log(doubled.value))

  watchEffect(() => console.log('Count: ', doubled.value))
})

// 处理掉当前作用域内的所有 effect
scope.stop()

在 Vue 的 setup 中,响应会在开始初始化的时候被收集,在实例被卸载的时候,响应就会自动的被取消追踪了,这时一个很方便的特性。

但是,当我们在组件外使用或者编写一个独立的包时,这会变得非常麻烦。当在单独的文件中,我们该如何停止 computed & watch 的响应式依赖呢?

示例代码,参考链接

const disposables = []

const counter = ref(0)
const doubled = computed(() => counter.value * 2)

disposables.push(() => stop(doubled.effect))

const stopWatch1 = watchEffect(() => {
  console.log(`counter: ${counter.value}`)
})

disposables.push(stopWatch1)

const stopWatch2 = watch(doubled, () => {
  console.log(doubled.value)
})

disposables.push(stopWatch2)

上面的代码中,我们写了一共三个 computed & watch 的响应式依赖,把这些响应式依赖的 stopHandle 都存到一个数组中,意思是我们需要维护这个数组,这样将来在需要的时候,就可以像下面这样,直接把所有的响应都停掉:

disposables.forEach((f) => f())
disposables = []

尤其是当我们有一些长而复杂的组合式函数代码时,手动收集所有响应式依赖是很费力的。也很容易忘记收集它们(或者您无法访问在组合式函数中创建的响应式依赖),这可能会导致内存泄漏和意外行为。

该特性就是试图将组件的 setup() 响应式依赖收集和处理功能抽象为更通用的 API,该 API 可以在组件模型之外复用。

它还提供了从组件的 setup() 范围或用户定义的范围创建“分离” effects 的功能。

这个功能解决了什么问题?

// global shared Reactive state
let foo

function useFoo() {
  if (!foo) { // lazy initialization
      foo = ref()
      watch(foo, ...) // <- this is stopped when component that created it is unmounted
      // make some Http calls etc
  }
  return foo
}

component1 = {
    setup() {
        useFoo() // lazily initialize
    }
}

component2 = {
    setup() {
        useFoo() // lazily initialize
    }
}

我有一个在多个组件之间共享功能的组合式函数,问题是当卸载第一个调用的组件时 component1 停止 useFoo 响应式依赖。因为如果不停止对全局变量 foo 又有影响,其他 component2 组件调用有问题。

到此这篇关于深入理解vue3里的EffectScope的文章就介绍到这了,更多相关Vue3 EffectScope内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: 深入理解Vue3里的EffectScope

本文链接: https://lsjlt.com/news/171994.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • 深入理解Vue3里的EffectScope
    Vue 3.2 版本引入了新的 Effect scope API,使用 effectScope 创建一个 effect 作用域,可以捕获其中所创建的响应式副作用 (即计算属性和侦听器...
    99+
    2022-11-13
    Vue3 EffectScope
  • Vue3里的EffectScope怎么使用
    Vue 3.2 版本引入了新的 Effect scope API,使用 effectScope 创建一个 effect 作用域,可以捕获其中所创建的响应式副作用 (即计算属性和侦听器),这样捕获到的副作用可以一起处理。getCurrentS...
    99+
    2023-05-17
    Vue3
  • 深入理解vue3中的reactive()
    目录开始调试复杂数据类型基本数据类型proxy对象ref类型Map类型和Set类型在vue3的开发中,reactive是提供实现响应式数据的方法。日常开发这个是使用频率很高的api。...
    99+
    2023-02-17
    vue3 reactive() vue  reactive
  • 对Vue3中reactive的深入理解
    目录Vue3 reactive的理解1.什么是reactive2.reactive注意点Vue3笔记 reactive函数Vue3 reactive的理解 1.什么是reactive...
    99+
    2024-04-02
  • 深入理解Vue3响应式原理
    目录响应式原理手写实现1、实现Reactive2、实现依赖的收集和触发effect影响函数收集/添加依赖触发依赖3、移除/停止依赖衍生类型1、实现readonly2、实现shallo...
    99+
    2022-12-19
    vue3响应式原理精讲 vue3 响应式 vue 响应式原理
  • 深入了解Vue3中props的原理与使用
    目录前言介绍原理前提创建组件实例对象初始化Props操作创建proxy对象去获取Propsprops作为参数传入setup将proxy挂载到render上总结前言 props指父组件...
    99+
    2023-05-19
    Vue3 props原理 Vue3 props使用 Vue3 props
  • 一文带你深入理解Vue3响应式原理
    目录 响应式原理2.0的不足reactive和effect的实现effect track trigger测试代码递归实现reactive总结 响应式原理 Vue2...
    99+
    2022-11-13
    vue3响应式原理精讲 vue3 响应式 vue 响应式原理
  • 深入了解Vue3中侦听器watcher的实现原理
    目录watch API 的用法watch API实现原理标准化source构造回调函数创建scheduler创建effect返回销毁函数异步任务队列的设计异步任务队列的创建异步任务队...
    99+
    2024-04-02
  • 深入聊聊vue3中的reactive()
    在vue3的开发中,reactive是提供实现响应式数据的方法。日常开发这个是使用频率很高的api。这篇文章笔者就来探索其内部运行机制。小白一枚,写得不好请多多见谅。调试版本为3.2.45什么是reactivereactive是Vue3中提...
    99+
    2023-05-14
    前端 Vue.js JavaScript
  • 怎么深入解析Vue3中的diff 算法
    今天给大家介绍一下怎么深入解析Vue3中的diff 算法。文章的内容小编觉得不错,现在给大家分享一下,觉得有需要的朋友可以了解一下,希望对大家有所帮助,下面跟着小编的思路一起来阅读吧。1.0  diff 无key子节点在处理被标记...
    99+
    2023-06-26
  • 深入详解Vue3中的Mock数据模拟
    目录引言一、Mock数据模拟的概述1.1 为什么需要Mock数据模拟?1.2 Mock数据模拟的优点和缺点二、安装和配置Mock.js库2.1 使用NPM安装Mock.js库2.2 ...
    99+
    2023-05-19
    Vue3 Mock数据模拟 Vue3 Mock
  • 由浅入深讲解vue2和vue3的区别
    目录前言vue2 vs vue3 对比双向绑定更新实例化生命周期获取props数据和方法的定义给父组件传值emitwatchEffect组件通信注意路由总结前言 vue2和vu3之前...
    99+
    2023-02-08
    vue2和vue3的区别是什么 vue2和vue3区别大吗 vue2和vue3原理的区别
  • 深入理解阿里云数据库
    简介:阿里云数据库是阿里云提供的一种基于云计算技术的数据库服务,为用户提供了丰富的数据库功能和管理工具,帮助用户快速构建和部署数据库应用程序。本文将深入探讨阿里云数据库的内容,包括数据库类型、数据库实例、数据库备份和恢复等方面。 数据库类型...
    99+
    2024-01-24
    阿里 数据库
  • 深入了解Vue3组件传值方式
    目录父子组件传值 props祖孙组件传值 provide 和 inject父组件中点击按钮向子组件传值今天说一下 vue3 的组件间传值,学习过 vue2 的宝子们肯定知道,组件传值...
    99+
    2024-04-02
  • 深入理解MessageQueue
    MessageQueue是一种用于线程间通信的机制,可以将消息从一个线程传递到另一个线程。它主要由两部分组成:消息队列和消息循环。消...
    99+
    2023-09-28
    MessageQueue
  • 深入理解quilljs
    Quill.js是一个用于构建富文本编辑器的JavaScript库。它提供了许多强大的功能,使开发人员能够轻松地创建具有格式化文本、...
    99+
    2023-09-22
    quilljs
  • 深入理解JavaScriptCore
    动态化作为移动客户端技术的一个重要分支,一直是业界积极探索的方向。目前业界流行的动态化方案,如Facebook的React Native,阿里巴巴的Weex都采用了前端系的DSL方案,而它们在iOS系统上能够顺利的运行,都离不开一个背后的功...
    99+
    2023-06-03
  • java String的深入理解
    java String的深入理解一、Java内存模型 按照官方的说法:Java 虚拟机具有一个堆,堆是运行时数据区域,所有类实例和数组的内存均从此处分配。     JVM主要管理两种类型内存...
    99+
    2023-05-31
    java string ava
  • 深入理解阿里云服务器WCS
    本文将深入介绍阿里云服务器WCS(Web Container Service)的基本概念、特点、优势以及如何使用它。 随着互联网的不断发展,Web应用的复杂度和规模也在不断提高。为了满足日益增长的Web应用需求,云服务已经成为主流。阿里云服...
    99+
    2023-11-12
    阿里 服务器 WCS
  • 深入了解vue2与vue3的生命周期对比
    目录周期对比用法总结 周期对比 vue2 vue3 ...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作