位置: IT常识 - 正文

vue3 使用defineAsyncComponent与component标签实现动态渲染组件(vue3.0用法)

编辑:rootadmin
vue3 使用defineAsyncComponent与component标签实现动态渲染组件

推荐整理分享vue3 使用defineAsyncComponent与component标签实现动态渲染组件(vue3.0用法),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:vue3.0用法,vue3使用ref,vue3使用ref,vue3使用ref,vue3使用ref,vue3使用$refs,vue3 definecomponent,vue3使用ref,内容如对您有帮助,希望把文章链接给更多的朋友!

内容有些啰嗦,内容记载了当时遇到了bug以及解决问题的思路。

业务场景简述: 前端做配置化组件,通过url内的唯一标识,请求后端sql 哪取页面配置信息,前端通过配置信息动态渲染查询表单,导出、表格,toolbar以及动态弹窗;该动态渲染组件的功能,就是渲染的toolbar内的按钮,类型为自定义弹窗,弹窗路径为后端配置数据,前端通过点击该按钮,打开指定路径下的弹窗组件。

vue3 使用defineAsyncComponent与component标签实现动态渲染组件(vue3.0用法)

之前用的vue2的动态挂载组件,也没见vue3那么麻烦,官网上的例子以及网上的所以例子都是前端知道要导哪些组件,然后程序进入就直接导进来了,只是写了逻辑动态切换。我这个不一样,需要挂载的组件是未知的。所以实现起来有点吃力。

一、基础的动态引入组件: 简单的动态引入的意思是,前端知道要引入哪些组件,将多个组件引入到父组件中,但不渲染它,满足一定条件后,才去在某个位置渲染指定的组件。

<template> <custom-modal ref="custom"></custom-modal></template><script> import { reactive, ref, shallowReactive, onActivated, defineAsyncComponent, } from 'vue'; const customModal = defineAsyncComponent(() => import('./modal/CustomModal.vue')); const custom = ref(); </script>

以上的例子就是通过vue的defineAsyncComponent实现挂载组件,并赋值给customModal ,模板中可以直接使用<custom-modal>作为标签使用,也可以将它赋值给component中的is属性,is属性执向一个变量,可通过业务逻辑动态,更改该变量的值,就可以实现多个组件进行来回的渲染了

<template><component :is="componentKey" ref="custom"></component></template> import { reactive, ref, shallowReactive, onActivated, defineAsyncComponent, } from 'vue'; const componentKey = ref(null); const components: any = shallowReactive({}); const customModal = defineAsyncComponent(() => import('./modal/CustomModal.vue')); componentKey = customModal

二、复杂的引入:不确定到底引入什么组件,组件的路径由后端返回 将以上代码 添加到项目代码中,并不能实现,虽然引入不报错,但是ref一直为undefined,无法调用动态组件内的open函数。 不断尝试了很多次,得出以下结论

1.起初是在按钮的click函数内去挂载自定义组件并调用ref函数的,ref为undefined。尝试多次不能实现功能(这里是挂载与调用最合适的位置),2.接着又在初始化配置数据时(查询后端sql),axios的then函数内挂载组件,然后点击按钮的地方调用ref内的函数,ref依旧为null。3. 接着在最外层,调用初始化时挂载,也就是生命周期函数体内,测试还是一样的结果。4. 接着发现带有async函数体内挂载组件,也无法完成。5.单独写个函数,不加async,函数内挂载组件,然后再生命周期外调用该函数,按钮内调用ref内的方法,成功弹窗。这并不是我想要的,因为路径不是固定的,它要等到后端sql放回结果,才能执行。

总结:上面的多次测试,得出以下结论,都不能让动态组件ref对象有值 1、不能在组件的事件函数内挂载,

2、不能在axios的then函数体内挂载

3、不能在带有async

本文链接地址:https://www.jiuchutong.com/zhishi/290778.html 转载请保留说明!

上一篇:伯尔尼老城,瑞士 (© Simon Zenger/Alamy)(瑞士伯尔尼小镇)

下一篇:【react从入门到精通】React JSX详解(react最新教程)

  • 小企业汇算清缴要审计报告吗
  • 财税新闻稿
  • 中国电信的通信网络
  • 工会经费的会计核算方法
  • 实收资本一直挂着其他应收款怎么办
  • 汇算清缴a107020表
  • 应收账款的损失率怎么算
  • 转让土地缴纳增值税进项如何抵扣
  • 存货计提减值准备是什么原则
  • 实物投资没有发票咋办
  • 未分配利润转增股本要交税吗
  • 2018企业所得税小微企业优惠政策
  • 退税勾选的发票账务处理
  • 增值税减税措施有哪些
  • 汇总缴纳增值税如何申报
  • 水利建设专项收入税
  • 旅游合同签订
  • 调整薪酬结构
  • 普票红冲后原件没有了怎么办
  • 申报的国家资助的一个项目如何进行账务处理?
  • 商业承兑汇票需要银行审核吗
  • 苹果电脑重新安装系统磁盘锁了怎么办
  • php获取远程文件数据
  • 支付货款的流程
  • lnmgr.exe是什么
  • win7怎么看服务
  • 新用户注册表单代码
  • 预缴企业所得税分录
  • 增值税报了所得税未报可以买发票吗
  • idea如何导入sql文件
  • php session_id
  • php中表单的使用
  • 基于个人同意处理个人信息的个人什么撤回其同意
  • 想要上海名媛群群号
  • mysql有几种
  • 认缴出资额就是营业执照上的注册资金
  • 房地产企业怎么预缴企业所得税
  • 所得税费用影响当期损益吗
  • 化妆品消费税纳税标准
  • 应收账款周转率越大越好还是越小越好
  • 旅游服务住宿费可以抵扣吗
  • 股权激励费用如何计提
  • 报销冲抵什么意思
  • 错帐的查找方法
  • 商场代收款合法吗
  • 营业外支出增加说明了什么
  • 跨月普票作废怎么处理操作步骤
  • sqlserver数据库迁移至mysql
  • win8.1升级win10系统
  • 关闭windowsxp窗口的方法有
  • windowsserver2008r2忘记开机密码怎么办
  • mac上dns设置
  • u盘安装win7系统教程图解
  • rhel7.4安装
  • mac截图后怎么编辑
  • ftp 550错误
  • win7系统任务栏跑到右侧怎么办
  • win7可以免费升win10
  • windows10无法关闭
  • windows8连接wifi
  • win7纯净版系统多大
  • win8怎样设置禁止弹出广告
  • errorlnk2019怎么解决
  • jquery 动态添加列表元素
  • js拖动图片
  • linux shell打开文件
  • a10 config backup for aXAPI
  • 杂志内页广告
  • cssdeck
  • angularjs input
  • shell脚本if用法
  • jQuery中bind(),live(),delegate(),on()绑定事件方法实例详解
  • unity打包全屏
  • jquery查找当前元素的父元素
  • JavaScript中Textarea滚动条不能拖动的解决方法
  • 志愿者开展活动后存在的问题
  • 税控盘的口令密码是什么
  • 个体工商户如何申报个税
  • 作为税务人员哪些基本素质
  • 什么是金融企业的固定推销人员
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设