vue element组件image-viewer使用注意

引用

在vue头中引用组件,因为image-viewer是属于Image组件中一个单独的功能,我们单独导入此包。
代码如下:

import ElImageViewer from 'element-ui/packages/image/src/image-viewer';

引用完了,注册为组件

//单个vue只引用这一个组件写法
components: {ElImageViewer},

使用:

<el-image-viewer
    v-if="showViewer"
    :on-close="()=>{showViewer=false}"
    :url-list="viewUrl"  />      

或者使用

<template slot-scope="scope">
    <el-image-viewer
         v-if="showViewer"
         :on-close="closeViewer"
         :url-list="viewUrl" style="color: red"/>
     <el-button type="text" v-bind:disable=" scope.row.urlList.length === 0" @click="onPreview(scope.row.urlList)">查看图片</el-button>
</template>

注意
showViewer:控制开关的绑定变量,可自定义。
on-close: 关闭事件,可绑定关闭触发事件。
url-list: 指向图片的url地址,用于显示预览的图片
viewUrl:此处为数组(viewUrl = [ ]),记得使用push存放,和清除数组的缓存。

举例

	showViewer: false,
    viewUrl: [
        'https://fuss10.elemecdn.com/8/27/f01c15bb73e1ef3793e64e6b7bbccjpeg.jpeg',
        'https://fuss10.elemecdn.com/1/8e/aeffeb4de74e2fde4bd74fc7b4486jpeg.jpeg'
    ]

js中函数

onPreview(path) {
	this.srcList = path
	this.showViewer = true
},
closeViewer() {
	this.showViewer = false
},

注意事项

1.记得初始化数组,保证你的数组数据正确
2.此处有用法上的歧义,当在for循环中调用此组件,因为其绑定的opacity(不透明)属性,在同一父级下透明度为父opacity*子opacity。所以单个图片的蒙层会和多图时蒙层颜色不一致(通俗讲,多个图片时,你的背景会是黑的)
解决方法:不在for中调用,只要保证你的每次打开时能将url赋值进你的viewUrl就行了。

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

绀香之末

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值