文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

vue2中怎么更改el-dialog出场动画

2023-07-02 10:18

关注

这篇文章主要讲解了“vue2中怎么更改el-dialog出场动画”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“vue2中怎么更改el-dialog出场动画”吧!

基本思路

.el-body分为两个部分,一个弹窗真正要展示的内容,一个出现、关闭时动画的图片展示(不一定是图片,本项目刚好是图片而已),在出场动画的过程中,图片逐渐消失,真正的内容发逐渐展现,看起来就像是原本那张图片通过旋转之后,变成了弹窗。

代码

首先,写一个常规的el-dialog,里面el-body分为两个部分,真正需要展示的内容和执行动画的图片:

<el-dialog    :visible.sync="visible"    top='0'  // 设置为零,方便后续的居中处理    title="详情弹窗"  >    <div class="show-info-facce">      <!-- 真正展示的内容 -->    </div>    <!-- 执行动画的图片 -->    <div class="animation-face">      <el-image v-if="showInfo.img" :src="showInfo.img" :fit="'contain'" class="show-img" />    </div>  </el-dialog>

然后,对.el-dialog元素的样式进行更改,主要是定位和居中处理,方便后续从某个位置逐渐旋转位移到屏幕中间:

  .el-dialog {    position: absolute;    // 根据项目中弹窗的大小设定的居中,用其他方式实现居中也行    left: calc(50% - 400px);    top: calc(50% - 242px);    overflow: hidden;    // 设置过渡,出现与消失的动画是靠过渡实现的    transition: all 1s;  }

这个时候,得到了一个居中与屏幕的弹窗,当然,别忘取消原来el-dialog的出现和消失动画:

.el-dialog__wrapper {  transition-duration: 0.1s;}.el-dialog__wrapper.dialog-fade-enter-active,.el-dialog__wrapper.dialog-fade-leave-active {  animation: none !important;}

这个时候就会得到一个没有动画的弹窗:

接下来,就是主要的动画部分了,在这个项目中,可以看到弹窗是在点击之后出现的,而这个点击实际上会操作一个控制弹窗是否出现的变量visible,来控制弹窗是否出现,本人把这个操作封装成一个函数show(),这个函数还接受展示内容的信息info

show(info) {    this.showInfo = info    this.visible = true}

到这个步骤为止,是大部分el-dialog的常规使用流程;从封面的动图可以看到,el-dialog是从被点击的图片位置出现的,而且弹窗出现后,原本的图片消失了。
这使得需要在show()获取被点击元素target来实现,这个不难获取,然后就是得到target的位置和大小,将el-dialog设为和target一样,接着使用上面用于执行动画的.animation-face元素来模拟原来的target,然后将target的不透明度opacity设为零,整体代码如下:

        show (target, info) {      // 记录target      this.targetEl = target      // 获取target的位置和大小      const position = target.getClientRects()[0]      // 获取.el-dialog元素,将其设为和`target`一样的大小和位置      const dialog = this.$el.querySelector('.el-dialog')      dialog.style.width = position.width + 'px'      dialog.style.height = position.height + 'px'      dialog.style.top = position.top + 'px'      dialog.style.left = position.left + 'px'      // 记录展示信息      this.showInfo = info      this.$nextTick(() => {        this.visible = true        // 原本的target设为透明        target.style.opacity = 0      })    }

已经得到了初步的效果了,接下来就是让弹窗旋转变大居中,这些都比较好实现的,可以通过设定行内样式或者添加class就行,因为前面已经在.el-dialog上设置好了过渡属性,只要某个属性发生变化,就会触发。
个人是通过添加class的方式,因为关闭的时候,弹窗还得回到原来target的位置上,到时候只要去除这个class就能实现,比较方便,变化的样式如下:

 .dialog-finally {    // 设定好最终展示的宽高    width: 800px !important;    height: 484px !important;    // 最终展示的位置    left: calc(50% - 400px) !important;    top: calc(50% - 242px) !important;    // 加点旋转    transform: rotateY(360deg);    // 执行动画的图片透明度设置为零,隐藏起来,显示出真正要展示的内容    div.animation-face {      opacity: 0;    }  }

然后在show函数中,给.el-dialog元素添加这个class,需要注意的是,直接添加会被vue2合并成一次更改,直接展示最终的样式,不会触发过渡效果,所以延时一会再把展示的class添加上去,完整的show()代码如下:

        show (target, info) {      // 记录target      this.targetEl = target      // 获取target的位置和大小      const position = target.getClientRects()[0]      // 获取.el-dialog元素,将其设为和`target`一样的大小和位置      const dialog = this.$el.querySelector('.el-dialog')      dialog.style.width = position.width + 'px'      dialog.style.height = position.height + 'px'      dialog.style.top = position.top + 'px'      dialog.style.left = position.left + 'px'      // 记录展示信息      this.showInfo = info      // 渲染初始位置      this.$nextTick(() => {        this.visible = true        // 延时添加最终样式        setTimeout(() => {          // 原本的target设为透明          target.style.opacity = 0          // 添加展示的class          dialog.classList.add('dialog-finally')        }, 50)      })    }

至此,出现的效果处理完成,接下来就是弹窗消失的效果,因为上面是使用class来添加展示的位置和样式的,所以关闭时,移除那个class就能让.el-dialog回到target的位置,那么需要使用el-dialog关闭之前的钩子before-close,该钩子接受一个函数,如下:

<el-dialog    :visible.sync="visible"    top='0'  // 设置为零,方便后续的居中处理    title="详情弹窗"    :before-close="handleAnimateClose" // 使用关闭之前的钩子  >    <div class="show-info-facce">      <!-- 真正展示的内容 -->    </div>    <!-- 执行动画的图片 -->    <div class="animation-face">      <el-image v-if="showInfo.img" :src="showInfo.img" :fit="'contain'" class="show-img" />    </div>  </el-dialog>

handleAnimateClose函数就是在关闭之前先移除展示的class,等弹窗回到target原本的位置之后,target的不透明度设置为1,关闭弹窗,代码如下:

        handleAnimateClose (done) {      // 获取`.el-dialog`元素      const dialog = this.$el.querySelector('.el-dialog')      // 移除展示的class      dialog.classList.remove('dialog-finally')      // 使用延时,等弹窗回到`target`原本的位置,再关闭弹窗      setTimeout(() => {        // 关闭弹窗        done()        // target不透明度设为1        this.targetEl.style.opacity = 1      }, 1000)    }

感谢各位的阅读,以上就是“vue2中怎么更改el-dialog出场动画”的内容了,经过本文的学习后,相信大家对vue2中怎么更改el-dialog出场动画这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯