Vue3.2组件如何封装,以弹窗组件的封装为例

以前一直想,每次封装一个弹窗组件的时候,一直特别复杂,父传子,子传父,各种来回绕,来回修改。
一直想如何才能更加简化,但是一直没时间,今天终于抽时间出来封装了一下
本次封装简化了很多的代码,再也不用父传子,子传父,各种来回绕,来回修改了。
实现功能如下:
js 复制代码
//拆分了表格组件和弹窗组件
//实现在父组件中,控制弹窗的显示与隐藏
//在弹窗子组件中,修改内容后,父组件内容对应更新。
2.所用技术
js 复制代码
//1.defineExpose 用于导出子组件的方法和数据
//2.defineEmits 用于子组件通知父组件执行操作
下面我来说一下,如何利用defineExpose和defineEmits来封装属于自己的组件吧
为了方便演示,这里就不上什么表格了,简单的用父组件和子组件进行演示,直接上代码
父组件代码
js 复制代码
<template>
 <div>
  <a-button type="primary" status="danger" @click="show">showModal</a-button>
  <!-- 为弹窗组件绑定ref  并且绑定子传父的emit事件 -->
  <homeModal ref="homeModalRef" @update="close"></homeModal>
 </div>
</template>

<script setup lang="ts">
import { ref, watch } from 'vue';
import homeModal from './component/homeModal.vue'

const homeModalRef = ref()
const show = () => {
  // 这里是调用了弹窗组件中的方法,实现弹窗的显示 用到了defineExpose方法
  homeModalRef.value.handleClick()
}

// 这里是接受触发事件后,父组件执行函数(各种请求)
const close = () => {
  getInitTable()
}
// 这里是模拟的函数请求方法
const getInitTable = () => {
  console.log('66666')
} 

</script>
<style scoped lang="less">
div{
  margin-top: 20px;
}
</style>
子组件代码
js 复制代码
<template>
  <div>
    <a-modal
      v-model:visible="visible"
      title="Modal Form"
      @cancel="handleCancel"
      @ok="handleOk"
    >
      <a-form :model="form">
        <a-form-item field="name" label="Name">
          <a-input v-model="form.name" />
        </a-form-item>
        <a-form-item field="post" label="Post">
          <a-select v-model="form.post">
            <a-option value="post1">Post1</a-option>
            <a-option value="post2">Post2</a-option>
            <a-option value="post3">Post3</a-option>
            <a-option value="post4">Post4</a-option>
          </a-select>
        </a-form-item>
      </a-form>
    </a-modal>
  </div>
</template>

<script setup lang="ts">
import { reactive, ref } from 'vue';
const visible = ref(false);

const form = reactive({
      name: '',
      post: ''
});

// 绑定emit事件
const emit = defineEmits<{
  (event:'update'):void
}>()

const handleClick = () => {
    visible.value = true;
};

const handleOk = () => {
  if (form.name !== '') {
    handleCancel()
    // 执行
    emit('update')
  }
};
const handleCancel = () => {
  visible.value = false;
}

// 导出方法
defineExpose({
  handleClick
})


</script>
<style scoped lang="less"></style>
相关推荐
一枚前端小能手1 分钟前
「周更第10期」实用JS库推荐:VueUse
前端·javascript·vue.js
前端摸鱼匠5 分钟前
Vue 3 事件修饰符全解析:从 .stop 到 .passive,彻底掌握前端交互的艺术
前端·vue.js·node.js·vue·交互
小摇21 分钟前
空值合并运算符`??`和逻辑或运算符 `||` 的区别
javascript
BraveAriesZyc23 分钟前
vue封装一个静态资源的文件
前端
FinClip24 分钟前
工行APP深夜惊魂!账户一夜清零,金融机构如何筑牢数字防火墙?
前端·javascript·github
inx17725 分钟前
用纯 CSS 实现甜蜜亲吻动画:关键帧与伪元素的实战练习
前端·css
JarvanMo26 分钟前
Flutter UI中的无声杀手
前端
inx17726 分钟前
从拼接到优雅:用 ES6 模板字符串和 map 打造更简洁的前端代码
前端·javascript·dom
AirDroid_cn26 分钟前
Windows11 Edge 浏览器访问麦克风被阻止如何解除?
前端·edge
pythonpioneer33 分钟前
【2025】Solid Edge下载安装教程(附安装包)保姆级安装步骤
前端·数据库·其他·edge