当前位置: 代码迷 >> 综合 >> vue day06
  详细解决方案

vue day06

热度:72   发布时间:2023-12-02 01:51:15.0

1.组件进阶 - 动态组件

  1. 准备被切换的 - UserName.vue / UserInfo.vue 2个组件

  2. 引入到UseDynamic.vue注册

  3. 准备变量来承载要显示的"组件名"

  4. 设置挂载点<component>, 使用is属性来设置要显示哪个组件

  5. 点击按钮 – 修改comName变量里的"组件名"

2.组件进阶 - 组件缓存

<div style="border: 1px solid red;"><!-- Vue内置keep-alive组件, 把包起来的组件缓存起来 --><keep-alive><component :is="comName"></component></keep-alive>
</div>

补充生命周期:

  • activated - 激活

  • deactivated - 失去激活状态

3.组件进阶 - 组件插槽

语法口诀:

  1. 组件内用<slot></slot>占位

  2. 使用组件时<Pannel></Pannel>夹着的地方, 传入标签替换slot

口诀: <slot>夹着内容默认显示内容, 如果不给插槽slot传东西, 则使用<slot>夹着的内容在原地显示

<slot>默认内容</slot>

4.组件进阶 - 具名插槽

<template><div><!-- 按钮标题 --><div class="title"><slot name="title"></slot><span class="btn" @click="isShow = !isShow">{
  { isShow ? "收起" : "展开" }}</span></div><!-- 下拉内容 --><div class="container" v-show="isShow"><slot name="content"></slot></div></div>
</template>
<template><div id="container"><div id="app"><h3>案例:折叠面板</h3><Pannel><template v-slot:title><h4>芙蓉楼送辛渐</h4></template><template v-slot:content><img src="../assets/mm.gif" alt=""><span>我是内容</span></template></Pannel><Pannel><template #title><span style="color: red;">我是标题</span></template><template #content><p>寒雨连江夜入吴,</p><p>平明送客楚山孤。</p><p>洛阳亲友如相问,</p><p>一片冰心在玉壶。</p></template></Pannel></div></div>
</template>

5.组件进阶 - 作用域插槽

口诀:

  1. 子组件, 在slot上绑定属性和子组件内的值

  2. 使用组件, 传入自定义标签, 用template和v-slot="自定义变量名"

  3. scope变量名自动绑定slot上所有属性和值

6.组件进阶 - 作用域插槽使用场景

案例: 封装一个表格组件, 在表格组件内循环产生单元格

准备MyTable.vue组件 – 内置表格, 传入数组循环铺设页面, 把对象每个内容显示在单元格里

准备UseTable.vue – 准备数据传入给MyTable.vue使用

7.自定义指令-注册/传值

注册:

<template><div><!-- <input type="text" v-gfocus> --><input type="text" v-focus></div>
</template>
?
<script>
// 目标: 创建 "自定义指令", 让输入框自动聚焦
// 1. 创建自定义指令
// 全局 / 局部
// 2. 在标签上使用自定义指令  v-指令名
// 注意:
// inserted方法 - 指令所在标签, 被插入到网页上触发(一次)
// update方法 - 指令对应数据/标签更新时, 此方法执行
export default {data(){return {colorStr: 'red'}},directives: {focus: {inserted(el){el.focus()}}}
}
</script>
?
<style>
?
</style>