vue3 、Element Plus新增公共组件或共用组件----Dialog 对话框组件

此环境在vue3下,用的是Element Plus组件库。

Dialog 对话框组件样式:

在这里插入图片描述

文件对应位置:

在这里插入图片描述文章来源地址https://uudwc.com/A/GVNpz

子组件代码:


<template>
    <div>
        <el-dialog :title="title" :model-value="dialogVisible" :append-to-body="true" :close-on-click-modal="clickClose"
            :width="width" :before-close="handleClose">
            <el-tabs type="border-card" style="margin-top:-20px">
                <el-tab-pane :label="subTitle ? subTitle : title">
                    <slot></slot>
                </el-tab-pane>
            </el-tabs>
        </el-dialog>
    </div>
</template>

<script lang='ts'>
import { defineComponent, reactive, toRefs, SetupContext } from 'vue'
interface Data {
    name: string;
}
export default defineComponent({
    name: '',
    props: {
        title: { //弹框标题,必传
            type: String,
            default: {}
        },
        dialogVisible: { //控制弹框显示隐藏,必传
            type: Boolean,
            default: {}
        },
        clickClose: { //点击弹框外是否已关闭,非必传
            type: Boolean,
            default: {}
        },
        width: { //弹框宽度,非必传
            type: String,
            default: {}
        },
        subTitle: { //tab标题,必传
            type: String,
            default: {}
        },
    },
    components: {

    },
    setup(props, context) {

        const state = reactive({
            name: '',
        })

        const methods = {
            handleClose: () => {
                context.emit('close', false)
            }
        }
        return {
            ...toRefs(state),
            ...methods,
        }
    },
})
</script>

<style scoped lang='scss'>
.el-dialog__header {
    padding: 10px 10px 10px 20px;
}

.el-dialog__body {
    // max-height: 600px;
    overflow: hidden;
    overflow-y: auto;
}
</style>

父组件代码:

<template>
  <div class="about">
    <h1>This is an about page</h1>
    <el-button text @click="open()">
      弹 框
    </el-button>

    <DialogCom :title="'测试'" :sub-title="'详情'" :dialog-visible="visible" :click-close="true" :width="'50%'"
      @close="cancel">
      <span>
        It should be noted that the content will not be aligned in center by
        default
      </span>
      <div class="dialog-footer">
        <el-button @click="cancel()">取 消</el-button>
        <el-button type="primary" @click="cancel()">
          确 定
        </el-button>
      </div>
    </DialogCom>
  </div>
</template>

<script lang='ts'>
import { defineComponent, reactive, toRefs, SetupContext } from 'vue'
import DialogCom from "@/components/DialogCom.vue"
export default defineComponent({
  // name: '',
  props: {
  },
  components: {
    DialogCom
  },
  setup(props) {

    const state = reactive({
      // name: '',
      visible: false,
    })
    const methods = {
      open: () => {
        state.visible = true
      },
      cancel: () => {
        state.visible = false
      }
    }
    return {
      ...toRefs(state),
      ...methods
    }
  },
})
</script>

<style scoped lang='scss'>
@media (min-width: 1024px) {
  .about {
    min-height: 100vh;
    display: flex;
    align-items: center;
  }
}

.dialog-footer {
  text-align: center;
  margin-top: 20px;
}
</style>

原文地址:https://blog.csdn.net/qq_39877681/article/details/128207827

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请联系站长进行投诉反馈,一经查实,立即删除!

h
上一篇 2023年07月16日 06:26
js实现自定义合并单元格,el-table开箱即用
下一篇 2023年07月16日 06:27