动态组件和异步组件

动态组件的用法 : :is= "属性名"

// is 必须是动态属性
component标签: < component :is=“NextTickName” />

动态组件怎么用呢?

根据原始数据动态渲染的场景,组件类型不确定的情况下。 比如说新闻落地页。

<!--<component  :is="NextTickName"/>-->
<div v-for="(val,key) in newsData" :key="key">
	<component :is="val.type"/>
</div>
<script>
 import NextTick from "./NextTick"
 export default {
  	components:{
		NextTick
	},
	data(){
		return{
			name:"哈哈哈",
			//NextTickName:"NextTick"
			//-- NextTick它是组件的名字 -- 
			newsData:{
				1:{
					type:"txet"
				},
				2:{
					type:"txet"
				}
				3:{
					type:"txet"
				}
			}
		}
	}
 }
</script>

异步组件:

在引入的组件内容过大的时候就可以用到异步组件,可以说它是按需加载,当用到的时候再去加载,而不是一次性去加载完成。

用法:

<FormDemo/>

<script>
	// import FormDemo from "./FormDemo";
	export default {
		compontents:{
			//它和上面的用法本质一样的,但是下面的是异步组件,也就是按需加载
			FormDemo:() => import("./FormDemo")
		}
	}
</script>
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、付费专栏及课程。

余额充值