1、动态组件
Vue提供了全局的内置组件,这些组件主要完成的都是功能封装
动态组件、缓存组件、分发组件 ?多个组件使用同一个挂载点,然后动态地在他们之间切换,称为动态组件 ? ?用法:<component :is=""></component> ?使用js属性动态绑定组件,决定那个组件被渲染
?
?
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title></title>
<script src="./js/vue.js"></script>
</head>
<body>
<div id="app">
<button @click=" flag = 'CompA' ">组件A</button>
<button @click=" flag = 'CompB' ">组件B</button>
<button @click=" flag = 'CompC' ">组件C</button>
<hr>
<!-- 动态绑定组件 -->
<component :is="flag"></component>
</div>
<script>
Vue.createApp({
data(){
return{
flag:"CompB"
}
},
components:{
CompA:{
template:'<h3>组件A</h3>'
},
CompB:{
template:'<h3>组件B</h3>'
},
CompC:{
template:'<h3>组件C</h3>'
}
}
}).mount('#app')
</script>
</body>
</html>
?2、缓存组件
缓存非活动的组件,可以保留组件的状态,避免重新渲染,默认每次都会销毁非活动组件并重新创建
一般会结合动态组件使用,用于缓存非活动的组件实例,避免组件的重复创建删除,提高性能
用法:<keep-alive>动态组件</keep-alive>
? ? ? ? ? ?<!-- 缓存组件 --> ?? ??? ??? ?<keep-alive> ?? ??? ??? ?<!-- 动态绑定组件 --> ?? ??? ??? ?<component :is="flag"></component> ?? ??? ??? ?</keep-alive>
?
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title></title>
<script src="./js/vue.js"></script>
</head>
<body>
<div id="app">
<button @click=" flag = 'CompA' ">组件A</button>
<button @click=" flag = 'CompB' ">组件B</button>
<button @click=" flag = 'CompC' ">组件C</button>
<hr>
<!-- 缓存组件 -->
<keep-alive>
<!-- 动态绑定组件 -->
<component :is="flag"></component>
</keep-alive>
</div>
<script>
Vue.createApp({
data(){
return{
flag:"CompB"
}
},
components:{
CompA:{
template:'<h3>组件A</h3>',
//观察组件的创建和销毁
created(){
console.log('组件A-----created创建')
},
unmounted(){
console.log('组件A-----unmounted卸载')
}
},
CompB:{
template:'<h3>组件B</h3>',
created(){
console.log('组件b-----created创建')
},
unmounted(){
console.log('组件b-----unmounted卸载')
}
},
CompC:{
template:'<h3>组件C</h3>',
created(){
console.log('组件c-----created创建')
},
unmounted(){
console.log('组件c-----unmounted卸载')
}
}
}
}).mount('#app')
</script>
</body>
</html>
缓存完之后!!!不管如何点击,只会创建三个组件。
?
3、分发组件
实现内容让的分发,可以在定义组件时指定插槽位置,调用组件时提供要替换插槽位置的内容
用法:<slot></slot> 具名插槽:为插槽指定名称,根据插槽名称进行内容分发 再定义插槽时,再slot标签上通过name属性为插槽指定名称 在提供插槽内容时,通过为template标签指定v-solt指令,并以指令参数表示插槽名称 ?插槽就是一个空余的位置
?
?
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title></title>
<script src="js/vue.js"></script>
</head>
<body>
<div id="app">
<!-- p标签和span标签内容会替换插槽的位置 -->
<comp-a>
<p>111</p>
</comp-a>
<hr>
<comp-a>
<span>222</span>
</comp-a>
<hr />
<!-- 具名插槽,就是给插槽起个别名 -->
<comp-b>
<template v-slot:n1>
<p>111...</p>
</template>
<template v-slot:n2>
<p>222...</p>
</template>
<template v-slot:n3>
<p>333...</p>
</template>
</comp-b>
</div>
<template id="a">
<div>
<h3>组件A</h3>
<!-- 定义插槽,就是占个位置 -->
<slot></slot>
</div>
</template>
<!-- 通过模板替换上面内容 -->
<template id="b">
<h3>组件B</h3>
<slot name='n1'></slot>
<h3>组件B</h3>
<slot name='n2'></slot>
<h3>组件B</h3>
<slot name='n3'></slot>
</template>
<script>
Vue.createApp({
data(){
return{
}
},
components:{
'comp-a':{
template:'#a'
},
'comp-b':{
template:"#b"
}
}
}).mount('#app')
</script>
</body>
</html>
?
|