文章详情

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

请输入下面的图形验证码

提交验证

短信预约提醒成功

vue动态组件如何使用

2023-06-29 06:13

关注

这篇文章主要介绍“vue动态组件如何使用”,在日常操作中,相信很多人在vue动态组件如何使用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”vue动态组件如何使用”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

1、基本使用

新建组件 Article.vue

<template>    <div>        <p>黄州东南三十里为沙湖,亦曰螺师店。予买田其间,因往相田得疾。</p>        <p>闻麻桥人庞安常善医而聋。遂往求疗。</p>        <p>安常虽聋,而颖悟绝人,以纸画字,书不数字,辄深了人意。</p>          <p>余戏之曰:“余以手为口,君以眼为耳,皆一时异人也。”</p>        <p>疾愈,与之同游清泉寺。</p>        <p>寺在蕲水郭门外二里许,有王逸少洗笔泉,水极甘,下临兰溪,溪水西流。</p>        <p>余作歌云:“山下兰芽短浸溪,松间沙路净无泥,萧萧暮雨子规啼。</p>        <p>谁道人生无再少?君看流水尚能西,休将白发唱黄鸡。”</p>        <p>是日剧饮而归。</p>      </div></template>

新建组件 Poetry.vue

<template>    <div>        <p>春宵</p>        <p>苏轼 </p>        <p>春宵一刻值千金,花有清香月有阴。</p>         <p>歌管楼台声细细,秋千院落夜沉沉。</p>       </div></template>

新建 Learn.vue

并在 Learn.vue 中引入 Article.vue 和 Poetry.vue

本文中 Learn.vue 、Article.vue、Poetry.vue 在同一文件夹下

<template>    <div>        <component :is="currentComponent"></component>        <button @click="changeComponent">修改组件</button>    </div></template><script>import Article from './Article.vue'import Poetry from './Poetry.vue'export default {    components: {        Article,        Poetry    },    data() {        return {            currentComponent: 'Article'        }    },    methods: {        changeComponent() {            this.currentComponent = 'Poetry'        }    }}</script>

动态组件,即使用 component 标签,通过 is 属性指定的名称来切换不同的组件

运行效果

vue动态组件如何使用

2、配合 keep-alive 使用

keep-alive 可以保持这些组件的状态,如果需要保持组件的状态,则需要配合 keep-alive 一起使用

先看需要保持状态,而不使用 keep-alive 的情况

新建 Manuscript.vue

<template>    <div>        <form action="">            <input type="text" name="title" />            <br>            <input type="text" name="content" />        </form>    </div></template>

修改 Learn.vue

<template>    <div>        <component :is="currentComponent"></component>        <button @click="changeComponent(1)">诗歌</button>        <button @click="changeComponent(2)">稿件</button>    </div></template><script>import Poetry from './Poetry.vue'import Manuscript from './Manuscript.vue'export default {    components: {        Poetry,        Manuscript    },    data() {        return {            currentComponent: 'Poetry'        }    },    methods: {        changeComponent(type) {            if(type == 1) {                this.currentComponent = 'Poetry'            }            if(type == 2) {                this.currentComponent = 'Manuscript'            }        }    }}</script>

运行效果

vue动态组件如何使用

 看运行效果,会发现在 稿件 中输入文字后,切回到 诗歌,再回到 稿件,之前的 稿件 信息就不见了

出现这个情况的原因是,每次切换新组件的时候,Vue 都创建了一个新的组件。因此,如果需要保存原来的组件信息,要配合 keep-alive 使用

添加 keep-alive 后的 Learn.vue

使用 <keep-alive> 标签将动态组件包裹起来

<template>    <div>        <keep-alive>            <component :is="currentComponent"></component>        </keep-alive>                <button @click="changeComponent(1)">诗歌</button>        <button @click="changeComponent(2)">稿件</button>    </div></template><script>import Poetry from './Poetry.vue'import Manuscript from './Manuscript.vue'export default {    components: {        Poetry,        Manuscript    },    data() {        return {            currentComponent: 'Poetry'        }    },    methods: {        changeComponent(type) {            if(type == 1) {                this.currentComponent = 'Poetry'            }            if(type == 2) {                this.currentComponent = 'Manuscript'            }        }    }}</script>

运行效果

vue动态组件如何使用

到此,关于“vue动态组件如何使用”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注编程网网站,小编会继续努力为大家带来更多实用的文章!

阅读原文内容投诉

免责声明:

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

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

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     801人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     348人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     311人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     432人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     220人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯