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

文章首发掘金,未经允许禁止转载~~\
具体效果可以直接复制代码到本地看哦~ 欢迎阅读点赞给个支持⭐️⭐️⭐️
目录
相关文章
|
1月前
|
JavaScript
基于Element UI或Element Plus实现具有倒计时的Message消息提示
本文介绍了如何在Element UI或Element Plus框架中实现具有倒计时功能的消息提示组件,支持多次点击生成多个独立倒计时的消息提示,并提供了详细的实现代码和使用示例。
177 1
基于Element UI或Element Plus实现具有倒计时的Message消息提示
|
22天前
|
存储 搜索推荐 Java
探索安卓开发中的自定义视图:打造个性化UI组件Java中的异常处理:从基础到高级
【8月更文挑战第29天】在安卓应用的海洋中,一个独特的用户界面(UI)能让应用脱颖而出。自定义视图是实现这一目标的强大工具。本文将通过一个简单的自定义计数器视图示例,展示如何从零开始创建一个具有独特风格和功能的安卓UI组件,并讨论在此过程中涉及的设计原则、性能优化和兼容性问题。准备好让你的应用与众不同了吗?让我们开始吧!
|
22天前
|
JavaScript 前端开发 安全
[译] 在 Vue 组件中分离 UI 和业务逻辑。
[译] 在 Vue 组件中分离 UI 和业务逻辑。
|
20天前
|
开发者 C# Android开发
明白吗?Xamarin与Native的终极对决:究竟哪种开发方式更适合您的项目需求,让我们一探究竟!
【8月更文挑战第31天】随着移动应用开发的普及,开发者面临多种技术选择。本文对比了跨平台解决方案Xamarin与原生开发方式的优势与劣势。Xamarin使用C#进行跨平台开发,代码复用率高,可大幅降低开发成本;但因基于抽象层,可能影响性能。原生开发则充分利用平台特性,提供最佳用户体验,但需维护多套代码库,增加工作量。开发者应根据项目需求、团队技能和预算综合考量,选择最适合的开发方式。
59 0
|
21天前
|
JavaScript 前端开发 开发者
决战前端之巅!Element UI与Vuetify谁才是Vue.js组件界的霸主?一场关于颜值与实力的较量!
【8月更文挑战第30天】本文对比了两款热门的Vue.js组件库——Element UI与Vuetify。Element UI由饿了么团队打造,提供多种高质量UI组件,设计简洁大方。Vuetify基于Material Design规范,支持Vue.js 2.0及3.0版本,具备前瞻性。两者均涵盖表单、导航、数据展示等组件,Element UI配置选项丰富,而Vuetify则提供了更深层的样式定制功能。开发者可根据项目需求及个人偏好选择合适的组件库。
67 0
|
21天前
|
JavaScript 开发者 UED
Vue.js组件库大对决:Element UI与Vuetify,开发者的罗密欧与朱丽叶!
【8月更文挑战第30天】Element UI和Vuetify是Vue.js开发中的热门组件库,前者简洁高效,后者遵循Material Design,国际化程度高。两者均提供丰富的组件支持,但Vuetify组件更多样,设计更灵活;Element UI在性能和中文支持上更优。文档方面,Element UI更直观易懂,而Vuetify配置灵活但学习成本稍高。选择时需综合考虑项目需求、团队背景及设计风格,以达到最佳开发效果。
65 0
|
1月前
|
数据可视化 数据挖掘 持续交付
Axure Web端元件库:从Quick UI到500+组件的飞跃
在快速变化的数字世界中,产品设计不仅仅是功能的堆砌,更是用户体验的精心雕琢。原型设计作为产品开发过程中的关键环节,其重要性不言而喻。Axure,作为业界领先的原型设计工具,凭借其强大的交互设计和丰富的功能,赢得了全球设计师和开发者的信赖。而Axure Web端元件库,则是这一平台上的一颗璀璨明珠,它以超过500个精心设计的组件为基础,为设计师们打开了一扇通往高效、高质量原型设计的大门。
|
4月前
|
前端开发 搜索推荐 开发者
SAP UI5 sap.m.Column 控件的 minScreenWidth 属性介绍
SAP UI5 sap.m.Column 控件的 minScreenWidth 属性介绍
|
4月前
|
JavaScript 前端开发 开发者
SAP UI5 控件 sap.m.ListBase 的 inset 属性的作用介绍
SAP UI5 控件 sap.m.ListBase 的 inset 属性的作用介绍
|
4月前
|
前端开发 JavaScript API
SAP UI5 sap.ui.require.toUrl 的作用介绍
SAP UI5 sap.ui.require.toUrl 的作用介绍