Vue基于iview table展示图片如何实现点击放大的功能?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。
首先先安装依赖:
npm install v-viewer --save
然后全局引入,我这边是在main.js里面操作写的:
import Viewer from 'v-viewer'
import 'viewerjs/dist/viewer.css'
然后注册下:
Vue.use(Viewer)
Viewer.setDefaults({
Options: { 'inline': true, 'button': true, 'navbar': true, 'title': true, 'toolbar': true, 'tooltip': true, 'movable': true, 'zoomable': true, 'rotatable': true, 'scalable': true, 'transition': true, 'fullscreen': true, 'keyboard': true, 'url': 'data-source' }
})
使用的一个demo就是:
<viewer :images="tupians">
<i-col span="4" v-for="item in tupians">
<p class="detailed">
<img :src="item.img" alt="">
</p>
</i-col>
</viewer>
其中item.img其实就是一个路径。
在回到iview表格中,
需要以
h('xxxx', {
props: {
trigger: 'hover',
placement: 'top',
content: '二维码'
}
}, [
])
这种格式渲染出来,第一个参数是标签,第二参数是标签里面可以含props(vue的v-bind),也可以包含属性。第三个参数是数组,表示子标签。子标签也是这种格式的,以此递归下去。
所以改写成这种格式的,在本人项目中的一个demo如下,就可以实现在表格中点击图片进行放大展示:
{
title: '二维码',
align: 'center',
render: (h, params) => {
console.log('h, param', params);
let devicesArr = [];
let photo = [];
photo.push('/erweima/'+params.row.pt_number+'.png');
devicesArr.push(
h('Tooltip', {
props: {
trigger: 'hover',
placement: 'top',
content: '二维码'
}
}, [
h('viewer', {
props:{
images:photo
}
}, [
h('img', {
attrs: {
src:photo[0],
style: 'width: 22px;margin-right:5px'
},
})
])
])
);
return h('p', devicesArr);
}
}
看完上述内容是否对您有帮助呢?如果还想对相关知识有进一步的了解或阅读更多相关文章,请关注亿速云行业资讯频道,感谢您对亿速云的支持。
亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。