• 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">
              <div class="detailed">
                <img :src="item.img" alt="">
              </div>
          </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: ' 22px;margin-right:5px'
    },
    })
    ])
    ])
    );
    return h('div', devicesArr);
    }
    }
    
    
  • 相关阅读:
    P1582 倒水 (二进制)
    P2014 选课 (树形动规)
    多项式前置技能——复数
    P3694 邦邦的大合唱站队 (状压DP)
    P1754 球迷购票问题 (卡特兰数,递推)
    [SCOI2003]字符串折叠 (区间DP)
    [SDOI2008]仪仗队 (欧拉函数)
    4-字符串
    3.输出,输入,基本数据类型
    2.栈,堆,寄存器的理解
  • 原文地址:https://www.cnblogs.com/chenmz1995/p/12301268.html
Copyright © 2020-2023  润新知