极乐门资源网 Design By www.ioogu.com
起因
在elementui组件库中,el-image组件有个预览图片功能,比较简洁,但是和图片绑定在一起,我们只想要一个单纯的预览组件,传递一个图片,通过事件方式,显示大图
分析
通过查看elementui的代码,发现在image(el-image组件)目录中里面有一个image-viewer组件, el-image组件的预览功能也是通过这一个组件实现的,只是官方没有把这个组件单独暴露出来
这里就比较简单了,我们可以使用手动导入组件的方式,引入image-viewer组件
image-viewer组件二次封装
这里大概做了三件事
- 组件方式导入element的image-viewer组件
- 使用$attrs和$listeners把上层的属性和方法,原封不动传递给image-viewer组件,不用手动处理属性和方法,除非添加额外的功能
- 修改关闭按钮的样式
<template> <div> <el-image-viewer v-bind="$attrs" v-on="$listeners" /> </div> </template> <script> // 手动导入图片预览组件 import ElImageViewer from 'element-ui/packages/image/src/image-viewer' export default { name: 'ImagePreview', components: { ElImageViewer } } </script> <style lang="scss" scoped> ::v-deep .el-image-viewer__btn.el-image-viewer__close { color: #fff; } </style>
使用
<template> <div> <el-button type="primary" @click="handlePictureCardPreview" >大图预览</el-button > <image-preview v-if="dialogVisible" :on-close=" () => { dialogVisible = false; } " :url-list="[dialogImageUrl]" /> </div> </template> <script> import ImagePreview from "@/components/ImagePreview"; export default { components: { ImagePreview, }, data() { return { imageUrl: "https://ss0.bdstatic.com/70cFuHSh_Q1YnxGkpoWK1HF6hhy/it/u=1483731740,4186543320&fm=26&gp=0.jpg", dialogImageUrl: "", dialogVisible: false, }; }, methods: { // 预览 handlePictureCardPreview() { this.dialogImageUrl = this.imageUrl; this.dialogVisible = true; } }, }; </script>
优化:点击mask遮罩层关闭图片预览
上面封装以后,可以很简单使用图片预览,美中不足的是,点击遮罩层,无法关闭大图预览,只能点击右上角关闭按钮,才会关闭预览,使用上不太方便
分析
在查看image-viewer组件的源码发现,关闭按钮绑定hide方法,用于关闭预览的,但是遮罩层没有绑定任何方法,遮罩层也没有对外暴露任何方法调用,难受~
解决方法
- 先获取image-viewer组件
- 随后获取到遮罩层元素,给遮罩层绑定一个方法,点击时候,就调用image-viewer组件里的hdie方法,达到关闭的目的
- 在卸载组件的时候,移除之前给遮罩层绑定的方法
- 点击遮罩关闭预览,对外暴露一个标志,控制是否点击遮罩关闭预览
完整代码如下:
<template> <div> <el-image-viewer ref="elImageViewer" v-bind="$attrs" v-on="$listeners" /> </div> </template> <script> import ElImageViewer from 'element-ui/packages/image/src/image-viewer' export default { name: 'ImagePreview', components: { ElImageViewer }, props: { // 点击mask是否隐藏大图 maskhide: { type: Boolean, default: true } }, mounted() { if (this.maskhide) { this.addHideToMask() } }, methods: { addHideToMask() { this.$viewer = this.$refs.elImageViewer if (this.$viewer) { // 获取遮罩层元素 const mask = this.$viewer.$el.querySelector('.el-image-viewer__mask') if (mask) { // 遮罩层增加点击事件,关闭预览 mask.addEventListener('click', this.hide) // hook卸载事件,移除之前添加在mask元素的事件 this.$once('hook:beforeMount', () => { mask && mask.removeEventListener('click', this.hide) }) } } }, hide() { this.$viewer && this.$viewer.hide() } } } </script> <style lang="scss" scoped> ::v-deep .el-image-viewer__btn.el-image-viewer__close { color: #fff; } </style>
查看在线示例
查看在线示例
以上就是elementui实现预览图片组件二次封装的详细内容,更多关于elementui 预览图片组件二次封装的资料请关注其它相关文章!
极乐门资源网 Design By www.ioogu.com
极乐门资源网
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件!
如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
极乐门资源网 Design By www.ioogu.com
暂无elementui实现预览图片组件二次封装的评论...
更新日志
2024年11月15日
2024年11月15日
- 草蜢.2001-《真经典》环球唱片[WAV+CUE]
- 群星.2009-第4届2008十大发烧唱片精选[FLAC+CUE]
- 丁红《女儿情》[DTS-WAV]
- 陈惠婷.2017-Voyager3【亚神音乐】【FLAC分轨】
- 群星.2001-华纳歌声魅影【华纳】【WAV+CUE】
- 张雨生.2016-雨后星空2CD【丰华】【WAV+CUE】
- 李雨寰《Break Free》[FLAC/分轨][533MB]
- 廖也欧《面朝大海》[320K/MP3][18.35MB]
- 廖也欧《面朝大海》[Hi-Res][24bit 48kHz][FLAC/分轨][170.14MB]
- s13T1夺冠五人名单都有谁 s13T1夺冠五人名单一览
- 英雄联盟T1战队队长都有谁 T1战队所有队长介绍
- skt历届战队成员都有哪些 skt历届战队成员名单盘点
- 妙音唱片《大热唱片3》[WAV+CUE]
- 费玉清《跟着地球旋转》滚石时代经典复刻[正版原抓WAV+CUE]
- 罗文甄妮-射雕英雄传(AMCD)(限量版)[WAV+CUE]