动态组件和异步组件

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>lesson 21</title>
    <script src="https://unpkg.com/vue@next"></script>
</head>
<body>
    <div id="root"></div>
</body>
<script>
    //动态组件:根据数据的变化,结合component 这个标签,来随时动态切换组件的实现
    //异步组件:异步执行某些组件的逻辑,这叫做异步组件

    const app = Vue.createApp({
        data() {
            return {
                currentItem: 'input-item'
            }
        },
        methods: {
            handleClick() {
                this.currentItem === 'input-item' ? this.currentItem = 'common-item' : this.currentItem = 'input-item';
            }
        },
        //keep-alive 保留缓存
        //  <component :is="name" /> 动态组件
        template: `
            <keep-alive>
                <component :is="currentItem" />
            </keep-alive>
            <input-item v-show="currentItem === 'input-item'" />
            <common-item v-show="currentItem === 'common-item'" />
            <button @click="handleClick">change</button>
            <common-item />
            <async-common-item />
        `
    });
    app.component('common-item', {
        template:`
            <div>hello-world</div>
        `
    });
    app.component('input-item', {
        template:
            `<div>
                <input />
            </div>`
    });

    app.component('async-common-item',Vue.defineAsyncComponent(() => {
        return new Promise((resolve, reject) => {
            setTimeout(() => {
                resolve({
                    template:`<div>this is an async component</div>`
                })
            }, 4000);
        })
    }))
    app.mount('#root');
    
</script>
</html>
Vue中可以使用动态组件异步组件来实现按需加载和优化性能。下面是两种方式的实现方法。 1. 动态组件 动态组件是通过使用`<component>`标签,并在`is`属性中指定组件名来实现的。动态组件可以在运行时动态绑定组件,实现按需加载。 示例代码: ```html <template> <div> <button @click="toggleComponent">Toggle Component</button> <component :is="currentComponent"></component> </div> </template> <script> import ComponentA from './ComponentA.vue'; import ComponentB from './ComponentB.vue'; export default { components: { ComponentA, ComponentB, }, data() { return { currentComponent: 'ComponentA', }; }, methods: { toggleComponent() { this.currentComponent = this.currentComponent === 'ComponentA' ? 'ComponentB' : 'ComponentA'; }, }, }; </script> ``` 2. 异步组件 异步组件是通过使用`Vue.component()`方法来实现的。该方法接收一个函数作为参数,函数返回一个`Promise`对象,在`Promise`对象被解决时,将组件作为参数传递给`Vue.component()`方法。 示例代码: ```html <template> <div> <button @click="loadComponent">Load Component</button> <component v-if="currentComponent" :is="currentComponent"></component> </div> </template> <script> export default { data() { return { currentComponent: null, }; }, methods: { async loadComponent() { const { default: ComponentC } = await import('./ComponentC.vue'); this.currentComponent = ComponentC; }, }, }; </script> ``` 在上面的代码中,我们使用了ES6的动态导入语法来异步加载组件。这将返回一个`Promise`对象,我们可以使用`await`关键字来等待`Promise`对象被解决。在`Promise`对象被解决时,我们将组件作为参数传递给`currentComponent`,并将其渲染到页面上。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值