返回顶部
首页 > 资讯 > 精选 >Vue3动态组件如何进行异常处理
  • 488
分享到

Vue3动态组件如何进行异常处理

2023-07-04 17:07:39 488人浏览 八月长安
摘要

这篇“vue3动态组件如何进行异常处理”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Vue3动态组件如何进行异常处理”文章吧

这篇“vue3动态组件如何进行异常处理”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Vue3动态组件如何进行异常处理”文章吧。

动态组件有两种常用场景:

一是动态路由:

// 动态路由export const asyncRouterMap: Array<RouteRecordRaw> = [  {    path: '/',    name: 'index',    meta: { title: '首页' },    component: BasicLayout, // 引用了 BasicLayout 组件    redirect: '/welcome',    children: [      {        path: 'welcome',        name: 'Welcome',        meta: { title: '引导页' },        component: () => import('@/views/welcome.vue')      },      ...    ]  }]

二是动态渲染组件,比如在 Tabs 中切换:

    <el-tabs :model-value="copyTabName" type="card">      <template v-for="item in tabList" :key="item.key || item.name">        <el-tab-pane          :name="item.key"          :label="item.name"          :disabled="item.disabled"          :lazy="item.lazy || true"        >          <template #label>            <span>              <component v-if="item.icon" :is="item.icon" />              {{ item.name }}            </span>          </template>          // 关键在这里          <component :key="item.key || item.name" :is="item.component" v-bind="item.props" />        </el-tab-pane>      </template>    </el-tabs>

在 vue2 中使用并不会引发什么其他的问题,但是当你将组件包装成一个响应式对象时,在 vue3 中,会出现一个警告:

Vue received a Component which was made a Reactive object. This can lead to unnecessary perfORMance overhead, and should be avoided by marking the component with markRaw or using shallowRef instead of ref.

出现这个警告是因为:使用 reactive 或 ref(在 data 函数中声明也是一样的)声明变量会做 proxy 代理,而我们组件代理之后并没有其他用处,为了节省性能开销,vue 推荐我们使用 shallowRef 或者 markRaw 跳过 proxy 代理。

解决方法如上所说,需要使用 shallowRef 或 markRaw 进行处理:

对于 Tabs 的处理:

import { markRaw, ref } from 'vue'import A from './components/A.vue'import B from './components/B.vue'interface ComponentList {  name: string  component: Component  // ...}const tab = ref<ComponentList[]>([{    name: "组件 A",    component: markRaw(A)}, {    name: "组件 B",    component: markRaw(B)}])

对于动态路由的处理:

import { markRaw } from 'vue'// 动态路由export const asyncRouterMap: Array<RouteRecordRaw> = [  {    path: '/',    name: 'home',    meta: { title: '首页' },    component: markRaw(BasicLayout), // 使用 markRaw    // ...  }]

而对于 shallowRef 和 markRaw,2 者的区别在于 shallowRef 只会对 value 的修改做出反应,比如:

const state = shallowRef({ count: 1 })// 不会触发更改state.value.count = 2// 会触发更改state.value = { count: 2 }

而 markRaw,是将一个对象标记为不可被转为代理。然后返回该对象本身。

const foo = markRaw({})console.log(isReactive(reactive(foo))) // false// 也适用于嵌套在其他响应性对象const bar = reactive({ foo })console.log(isReactive(bar.foo)) // false

可看到,被 markRaw 处理过的对象已经不是一个响应式对象了。

对于一个组件来说,它不应该是一个响应式对象,在处理时,shallowRef 和 markRaw 2 个 api,推荐使用 markRaw 进行处理。

以上就是关于“Vue3动态组件如何进行异常处理”这篇文章的内容,相信大家都有了一定的了解,希望小编分享的内容对大家有帮助,若想了解更多相关的知识内容,请关注编程网精选频道。

--结束END--

本文标题: Vue3动态组件如何进行异常处理

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

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

猜你喜欢
  • Vue3动态组件如何进行异常处理
    这篇“Vue3动态组件如何进行异常处理”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Vue3动态组件如何进行异常处理”文章吧...
    99+
    2023-07-04
  • 浅析Vue3动态组件怎么进行异常处理
    Vue3动态组件怎么进行异常处理?下面本篇文章带大家聊聊Vue3 动态组件异常处理的方法,希望对大家有所帮助!【相关推荐:vuejs视频教程】动态组件有两种常用场景:一是动态路由:// 动态路由 export const asyncRout...
    99+
    2023-05-14
    前端 Vue.js JavaScript
  • Vue3如何进行全局异常处理
    本篇内容主要讲解“Vue3如何进行全局异常处理”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Vue3如何进行全局异常处理”吧!在开发组件库或者插件,经常会需要进行全局异常处理,从而实现:全局统一...
    99+
    2023-06-29
  • Vue动态组件实现异常处理方法
    动态组件有两种常用场景: 一是动态路由: // 动态路由 export const asyncRouterMap: Array<RouteRecordRaw> = [ ...
    99+
    2023-02-01
    Vue动态组件 Vue动态组件异常处理
  • vue3动态组件如何使用
    这篇“vue3动态组件如何使用”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“vue3动态组件如何使用”文章吧。问题:为什么v...
    99+
    2023-07-05
  • 如何在Python中进行异常处理
    目录一、抛出异常和自定义异常1、raise语句2、自定义异常类型二、捕捉异常1、捕捉多个异常2、获取异常信息三、finally子句一、抛出异常和自定义异常 Python中使用用异常对...
    99+
    2024-04-02
  • SpringBoot中如何进行统一异常处理
    目录1、处理前2、进行系统异常全局处理3、进行自定义异常处理总结如何在SpringBoot项目里进行统一异常处理 需要了解的知识 @ControllerAdvice的作用 1、处理前...
    99+
    2024-04-02
  • 如何在Spring Boot中进行异常处理
    这篇文章将为大家详细讲解有关如何在Spring Boot中进行异常处理,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。通过这篇文章,可以搞懂如何在 Sprin...
    99+
    2024-04-02
  • 如何进行C++代码的异常处理?
    如何进行C++代码的异常处理引言:在编写C++代码时,异常处理是非常重要的一部分。异常处理机制可以帮助我们在程序运行时捕获和处理错误。在本文中,我们将讨论一些关于如何在C++中进行异常处理的重要概念和技巧。一、异常处理的基本概念异常处理是一...
    99+
    2023-11-02
    代码 C++ 异常处理
  • C++ 函数库如何进行异常处理?
    c++++ 函数库异常处理通过 try-catch 语句实现,可捕获异常类型并进行处理。常见异常类型包括逻辑错误、运行时错误、内存分配失败、类型转换失败、索引超范围。实战案例演示了文件读...
    99+
    2024-04-18
    c++ 异常处理 标准库
  • vue3的动态组件是如何工作的
    目录一、组件注册 1.1 全局注册 1.2 注册全局组件的过程 1.3 应用挂载的过程 二、动态组件 2.1 绑定字符串类型 2.2 绑定对象类型 三、阿宝哥有话说 3.1 除了 c...
    99+
    2024-04-02
  • windows异常进程如何处理
    处理Windows异常进程的方法通常有以下几种:1. 结束进程:打开任务管理器,在“进程”选项卡中找到异常进程,右键点击选择“结束任...
    99+
    2023-10-09
    windows
  • 怎么进行Oracle异常处理
    这篇文章给大家介绍怎么进行Oracle异常处理,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。1、异常的优点      如果没有异常,在程序中,应当检查每个命令的成功...
    99+
    2024-04-02
  • 如何进行C++代码的优雅异常处理?
    如何进行C++代码的优雅异常处理?在编程过程中,异常处理是一个重要的方面。异常处理可以帮助我们在代码执行过程中处理意外情况,保证程序的稳定性和可靠性。在C++中,异常处理的机制能有效地捕获和处理错误,从而帮助我们优雅地处理异常情况。本文将介...
    99+
    2023-11-02
    异常处理 (Exception Handling) C++编程 (C++ programming) 优雅异常 (Grac
  • C++ 技术中的异常处理:如何使用异常处理来进行错误处理和恢复?
    答案:c++++ 中的异常处理可用于处理和恢复运行时错误。异常处理机制:异常抛出:使用 throw 关键字抛出异常对象。异常捕获:catch 块捕获抛出的异常。异常处理:try-catc...
    99+
    2024-05-09
    错误处理 异常处理 c++
  • 如何在Python中使用Selenium对异常进行处理
    这篇文章主要介绍了如何在Python中使用Selenium对异常进行处理,编程网小编觉得不错,现在分享给大家,也给大家做个参考,一起跟随编程网小编来看看吧!python是什么意思Python是一种跨平台的、具有解释性、编译性、互动性和面向对...
    99+
    2023-06-06
  • PHP中如何进行异常数据检测和处理?
    在编写PHP应用程序时,异常数据可能会在很多情况下出现。例如,用户提交的表单数据可能会包含不合法的输入,像特殊字符或过长的文本。在这种情况下,应该对异常数据进行有效的检测和处理,以避免安全漏洞或程序崩溃的发生。本篇文章将介绍PHP中如何进行...
    99+
    2023-05-22
    异常处理 数据检测 PHP
  • 如何在SpringBoot项目里进行统一异常处理
    目录1、处理前2、进行系统异常全局处理3、进行自定义异常处理效果前言: 需要了解的知识: @ControllerAdvice的作用 1、处理前 异常代码: @ApiOperatio...
    99+
    2024-04-02
  • 使用spring boot如何对异常请求进行处理
    这期内容当中小编将会给大家带来有关使用spring boot如何对异常请求进行处理,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。404异常处理:@Controllerpublic class&n...
    99+
    2023-05-31
    springboot 进行处理
  • C++ 函数重载中的异常处理如何进行?
    c++++ 中重载函数的异常处理遵循单一异常处理点原则。noexcept 规范符用于指定函数是否引发异常:noexcept(true) 表示不引发,noexcept(false) 则表示...
    99+
    2024-04-27
    c++ 异常处理 作用域
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作