我的编程空间,编程开发者的网络收藏夹
学习永远不晚

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

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

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动态组件如何进行异常处理”这篇文章的内容,相信大家都有了一定的了解,希望小编分享的内容对大家有帮助,若想了解更多相关的知识内容,请关注编程网行业资讯频道。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

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

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

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

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

浅析Vue3动态组件怎么进行异常处理

Vue3动态组件怎么进行异常处理?下面本篇文章带大家聊聊Vue3 动态组件异常处理的方法,希望对大家有所帮助!
2023-05-14

Vue3如何进行全局异常处理

本篇内容主要讲解“Vue3如何进行全局异常处理”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Vue3如何进行全局异常处理”吧!在开发组件库或者插件,经常会需要进行全局异常处理,从而实现:全局统一
2023-06-29

Vue动态组件实现异常处理方法

Vue3动态组件怎么进行异常处理?下面本篇文章带大家聊聊Vue3动态组件异常处理的方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习吧
2023-02-01

vue3动态组件如何使用

这篇“vue3动态组件如何使用”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“vue3动态组件如何使用”文章吧。问题:为什么v
2023-07-05

如何进行C++代码的异常处理?

如何进行C++代码的异常处理?引言:在编写C++代码时,异常处理是非常重要的一部分。异常处理机制可以帮助我们在程序运行时捕获和处理错误。在本文中,我们将讨论一些关于如何在C++中进行异常处理的重要概念和技巧。一、异常处理的基本概念异常处理是
如何进行C++代码的异常处理?
2023-11-02

C++ 函数库如何进行异常处理?

c++++ 函数库异常处理通过 try-catch 语句实现,可捕获异常类型并进行处理。常见异常类型包括逻辑错误、运行时错误、内存分配失败、类型转换失败、索引超范围。实战案例演示了文件读取时的异常处理,可输出错误信息或采取相应措施。C++
C++ 函数库如何进行异常处理?
2024-04-18

windows异常进程如何处理

处理Windows异常进程的方法通常有以下几种:1. 结束进程:打开任务管理器,在“进程”选项卡中找到异常进程,右键点击选择“结束任务”。这将强制终止该进程,并关闭它的所有相关任务。2. 重启计算机:有时,异常进程可能无法通过结束任务来解决
2023-10-09

如何进行C++代码的优雅异常处理?

如何进行C++代码的优雅异常处理?在编程过程中,异常处理是一个重要的方面。异常处理可以帮助我们在代码执行过程中处理意外情况,保证程序的稳定性和可靠性。在C++中,异常处理的机制能有效地捕获和处理错误,从而帮助我们优雅地处理异常情况。本文将介
如何进行C++代码的优雅异常处理?
2023-11-02

C++ 技术中的异常处理:如何使用异常处理来进行错误处理和恢复?

答案:c++++ 中的异常处理可用于处理和恢复运行时错误。异常处理机制:异常抛出:使用 throw 关键字抛出异常对象。异常捕获:catch 块捕获抛出的异常。异常处理:try-catch 块包围可能抛出异常的代码。最佳实践:仅在需要时使用
C++ 技术中的异常处理:如何使用异常处理来进行错误处理和恢复?
2024-05-09

C++ 函数重载中的异常处理如何进行?

c++++ 中重载函数的异常处理遵循单一异常处理点原则。noexcept 规范符用于指定函数是否引发异常:noexcept(true) 表示不引发,noexcept(false) 则表示可能引发。异常处理代码只能出现在一个函数版本中,通常位
C++ 函数重载中的异常处理如何进行?
2024-04-27

使用spring boot如何对异常请求进行处理

这期内容当中小编将会给大家带来有关使用spring boot如何对异常请求进行处理,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。404异常处理:@Controllerpublic class ErrorH
2023-05-31

如何在Python中使用Selenium对异常进行处理

这篇文章主要介绍了如何在Python中使用Selenium对异常进行处理,编程网小编觉得不错,现在分享给大家,也给大家做个参考,一起跟随编程网小编来看看吧!python是什么意思Python是一种跨平台的、具有解释性、编译性、互动性和面向对
2023-06-06

PHP如何在Yii框架中进行错误和异常处理

这篇文章主要讲解了“PHP如何在Yii框架中进行错误和异常处理”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“PHP如何在Yii框架中进行错误和异常处理”吧!Yii已经默认已经在CApplic
2023-06-20

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录