站长资讯网
最全最丰富的资讯网站

Vue基于iview table展示图片实现点击放大功能

Vue基于iview table展示图片实现点击放大功能

首先先安装依赖:

npm install v-viewer --save

然后全局引入,我这边是在main.js里面操作写的:

import Viewer from 'v-viewer'
import 'viewerjs/dist/viewer.css'

相关学习推荐:javascript教程

然后注册下:

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);   } }

相关学习推荐:编程视频

赞(0)
分享到: 更多 (0)
网站地图   沪ICP备18035694号-2    沪公网安备31011702889846号