位置: 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最新教程)

  • 现在会计账簿还需要交印花税吗
  • 换汇成本太低怎么处理?
  • 房租收入如何缴税?
  • 突然收到财付通转出的钱
  • 国税一个月没报税罚款多少
  • 员工异地交纳保险怎么交
  • 一般纳税人开培训发票税率是多少
  • 国外公司进口能退税吗
  • 预售 首付
  • 哪些项目可以享受简易征收
  • 国内外经典案例
  • 本期认证本期不抵扣下月再抵扣
  • 公司个税申报是什么意思
  • etc发票犯法吗
  • 长期股权投资的初始计量
  • 个税计算方法举例讲解
  • 应计提的存货跌价准备
  • 总公司资金转入私人账户
  • 生产的废料怎么做账
  • 费用报销单应怎样填写
  • 股东分配利润的程序
  • 个人所得税如何退税操作步骤
  • php数组函数实现机选双色球
  • 企业所得税汇算清缴
  • 公司的对公账户
  • 其他暂收和应付账款区别
  • 增值税发票要审核成功才能开吗
  • ros source
  • vrvarp.exe是什么
  • php变量用什么符号
  • php imagestring
  • 房地产企业收入确认
  • php read
  • 车辆被盗
  • 总账会计工作职责精选汇总
  • metric命令
  • 扣发工资是发还是不发
  • ps打不出字怎么回事
  • python语言接收信息的内置函数
  • 资产负债表上应付账款根据什么填制
  • 非金融企业之间借款利息可以抵扣吗
  • 租赁办公场所的法律规定
  • python knn算法和结果
  • 税率免税的发票
  • 运输公司燃油费占比
  • 国税局网上申报
  • 金蝶k3如何设置现金流量表取数公式
  • 商业会计怎么算主营业务成本
  • 工会经费的开支必须取得发票么
  • 长期借款短期利息怎么算
  • 小规模应交增值税怎么算出来的
  • 如何理解啥意思
  • 专票错误已认证需要退回吗?
  • 规范专户资金使用
  • 受同一方重大影响的企业之间为什么不构成关联方
  • 什么是折旧费
  • 哪些会计凭证可以抵扣进项税
  • windowsxp的开始菜单
  • Ubuntu上安装jdk
  • macbookair网页视频看不了
  • 你一定不知道的56个历史真相
  • window xp电脑连接宽带怎么连接
  • 关闭5gwifi
  • redhat下载教程
  • 苹果知识大全
  • gws.exe是啥
  • nb3是什么文件
  • java.exe是指
  • linux lvm2_member
  • cocos2dx 3.4 lua加密 setXXTEAKeyAndSign
  • perl中\s+
  • unity3d脚本执行顺序
  • retrofit提交表单
  • unity怎么加人
  • jquery动态
  • javascript怎么关
  • flask框架数据可视化
  • 2022年企业所得税税率2.5% 10% 25%
  • 南京税务证明怎么打印
  • 怎样查询上一年的国税
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设