Element ui dialog弹窗最大化最小化关闭组件封装

简介: 封装一个最大化最小化关闭的dialog弹窗组件
学习过程中将笔记整理跟大家分享,希望对大家也有所帮助,共同成长进步💪~\
如果大家喜欢,可以点赞或留言💕 ~~,谢谢大家⭐️⭐️⭐️~

注:往往项目上有些弹窗就会被要求可最大化最小化操作,所以今天封装了一个弹窗最大化最小化关闭的一个组件封装,废话不多说,下面直接上代码了:

首先封装一个最大化最小化关闭的dialogHeader子组件

<!--最大化最小化组件封装-->
<template>
  <div class="header-title">
      <span class="title-name">{{ dialogTittle }}</span>
      <span 
          style="float: right; color: #909399; cursor: pointer;" 
          class="el-icon-close" 
          @click="() => closed"></span>
      <span 
          style="float: right; margin-right: 10px; color:#909399; cursor: pointer;" 
          :class="flodIconClass"
          @click="() => isFullscreen"></span>
  </div>
</template>

<script>
export default {
  props: {
    dialogTittle: {
        type: String,
        default: () => ''
    },
    fullscreen: {
        type: Boolean,
        default: () => false
    }
  },
  data () {
    return {
      header_box: {
          'display': 'flex',
          'align-items': 'center'
      }
    }
  },
  computed: {
      flodIconClass() {
          return this.fullscreen ? 'el-icon-full-screen' : 'el-icon-copy-document';
      },
      isFullscreen() {
          this.$emit('is-fullscreen', !this.fullscreen);
      },
      closed() {
          this.$emit('handle-closed', 2)
      }
  },
  created() {
  
  },
  methods: {
      
  },
  mounted() {
    
  },
}
</script>

dialogHeaderpage主页面引用dialogHeader子组件使用

<template>
  <div class="hello">
    <el-button type="primary" size="small" @click="addProject">新增项目</el-button>
    <el-dialog title="新增" :class="isFullscreen ? '' : 'dialogClass_his'"
        custom-class="handleDialogClass" width="73.4%" :fullscreen="isFullscreen" v-if="dialogVisible_add"
        :visible.sync="dialogVisible_add" :show-close="false" :close-on-click-modal="false"
        :close-on-press-escape="false">
        <dialog-header slot="title" dialog-tittle="新增" :fullscreen="isFullscreen" @handle-closed="dialogClose"
            @is-fullscreen="onFullscreen"></dialog-header>
        <div>弹窗内容</div>
    </el-dialog>
  </div>
</template>

<script>
import dialogHeader from '@/components/dialogHeader'
export default {
  components:{
      'dialog-header':dialogHeader,
  },
  data () {
    return {
      dialogVisible_add: false,
      isFullscreen: false,
    }
  },
  methods: {
    //弹出弹窗显示
    addProject(){
      this.dialogVisible_add = true;
    },
    //是否为全屏函数
    onFullscreen(fullscreen) {
        this.isFullscreen = fullscreen;
    },
    //关闭事件
    dialogClose() {
        this.dialogVisible_add = false;
    },
  },
  mounted() {

  },
}
</script>

注:

custom-class: Dialog 的自定义类名(string)

fullscreen:是否为全屏 Dialog(boolean)

show-close:是否显示关闭按钮(boolean)

close-on-click-modal: 是否可以通过点击 modal 关闭 Dialog(boolean)

close-on-press-escape: 是否可以通过按下 ESC 关闭 Dialog(boolean)

效果图如下:

image.png

image.png

文章首发掘金,未经允许禁止转载~~\
具体效果可以直接复制代码到本地看哦~ 欢迎阅读点赞给个支持⭐️⭐️⭐️
目录
相关文章
|
6天前
|
JavaScript 前端开发
如何优雅的只在当前页面中覆盖ui库中组件的样式(vue的问题)
如何优雅的只在当前页面中覆盖ui库中组件的样式(vue的问题)
20 0
如何优雅的只在当前页面中覆盖ui库中组件的样式(vue的问题)
|
6天前
|
JavaScript
Vue给Element UI的el-popconfirm绑定按钮事件
Vue给Element UI的el-popconfirm绑定按钮事件
|
5天前
|
Android开发 算法 架构师
android的基础ui组件,这些知识点你会吗
android的基础ui组件,这些知识点你会吗
android的基础ui组件,这些知识点你会吗
|
5天前
|
Android开发 缓存 双11
android的基础ui组件,Android开发社招面试经验
android的基础ui组件,Android开发社招面试经验
android的基础ui组件,Android开发社招面试经验
|
4天前
Vue3+Vite+Pinia+Naive后台管理系统搭建之四:Naive UI 组件库的安装和使用
Vue3+Vite+Pinia+Naive后台管理系统搭建之四:Naive UI 组件库的安装和使用
9 1
|
6天前
|
前端开发 搜索推荐 UED
【Flutter前端技术开发专栏】Flutter中的高级UI组件应用
【4月更文挑战第30天】探索Flutter的高级UI组件,如`TabBar`、`Drawer`、`BottomSheet`,提升应用体验和美观度。使用高级组件能节省开发时间,提供内置交互逻辑和优秀视觉效果。示例代码展示了如何实现底部导航栏、侧边导航和底部弹出菜单。同时,自定义组件允许个性化设计和功能扩展,但也带来性能优化和维护挑战。参考Flutter官方文档和教程,深入学习并有效利用这些组件。
【Flutter前端技术开发专栏】Flutter中的高级UI组件应用
|
6天前
|
前端开发 JavaScript UED
前端UI组件
前端UI组件
24 0
|
6天前
|
JavaScript
vue element ui 打开弹窗出现黑框问题
vue element ui 打开弹窗出现黑框问题
22 1
|
6天前
|
编解码 JavaScript 数据可视化
【vue3】 vue3 几款值得推荐的UI组件库
【vue3】 vue3 几款值得推荐的UI组件库
102 0
|
6天前
【UI】 element ui 表格没有数据时用--填充
【UI】 element ui 表格没有数据时用--填充
23 2

热门文章

最新文章