vue高级组件封装 element组件二次封装

vue高级组件封装 element组件二次封装

相关解读

  1. 使用defineOptions定义组件名称
  2. 使用useSlots获取插槽 获取父组件传递过来的dialog组件的插槽 通过循环直接通过动态插槽插入el-dialog组件中
  3. 使用defineExpose暴露组件方法 父组件可通过ref直接调用
  4. 使用v-bind="$attrs"绑定父组件传递的属性
  5. 使用v-bind="slotProps"绑定插槽属性
  6. 经过这些处理可直接在使用这个组件的地方 透传el-dialog组件的属性和插槽 同时能接受el-dialog抛出的方法

组件封装

js 复制代码
<template>
  <el-dialog
    v-model="dialogVisible"
    v-bind="$attrs"
    append-to-body
    class="my-dialog"
  >
    <template v-for="(_,name) in slots" #[name]="slotProps">
      <slot :name="name" v-bind="slotProps"></slot>
    </template>
  </el-dialog>
</template>

<script setup lang="ts">
import { useSlots, Slots } from 'vue';
defineOptions({
  name: 'MyDialog'
})
const slots:Slots  = useSlots();
const dialogVisible = ref(false)
const init = () => {
  dialogVisible.value = true
}
defineExpose({
 init
})
</script>

<style lang="scss">
// 重新定义弹窗样式
.my-dialog{

}
</style>

组件使用

js 复制代码
<template>
  <MyDialog ref="myDialog" width="500px" top="20vh" draggable @closed="handleClosed">
  </MyDialog>
</template>
<script setup lang="ts">
  const myDialog = ref()
  const handleClosed = () => {
    console.log('closed')
  }
  onMounted(() => {
    myDialog.value?.init()
  })
</script>
相关推荐
烬头88212 小时前
React Native鸿蒙跨平台采用了函数式组件的形式,通过 props 接收分类数据,使用 TouchableOpacity实现了点击交互效果
javascript·react native·react.js·ecmascript·交互·harmonyos
Amumu121382 小时前
Vuex介绍
前端·javascript·vue.js
2601_949809592 小时前
flutter_for_openharmony家庭相册app实战+相册详情实现
javascript·flutter·ajax
qq_177767372 小时前
React Native鸿蒙跨平台通过Animated.Value.interpolate实现滚动距离到动画属性的映射
javascript·react native·react.js·harmonyos
2601_949833393 小时前
flutter_for_openharmony口腔护理app实战+饮食记录实现
android·javascript·flutter
2601_949480063 小时前
【无标题】
开发语言·前端·javascript
css趣多多3 小时前
Vue过滤器
前端·javascript·vue.js
●VON3 小时前
React Native for OpenHarmony:项目目录结构与跨平台构建流程详解
javascript·学习·react native·react.js·架构·跨平台·von
爱吃大芒果4 小时前
Flutter for OpenHarmony 实战:mango_shop 路由系统的配置与页面跳转逻辑
开发语言·javascript·flutter
qq_177767374 小时前
React Native鸿蒙跨平台实现消息列表用于存储所有消息数据,筛选状态用于控制消息筛选结果
javascript·react native·react.js·ecmascript·harmonyos