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


Posted in Javascript onAugust 05, 2020

首先先安装依赖:

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: 'width: 22px;margin-right:5px'
            },
          })
        ])
      ])
    );
    return h('div', devicesArr);
  }
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
javascript parseInt 大改造
Sep 27 Javascript
jquery二级导航内容均分的原理及实现
Aug 13 Javascript
JS实现字体选色板实例代码
Nov 20 Javascript
一个很有趣3D球状标签云兼容IE8
Aug 22 Javascript
javascript初学者常用技巧
Sep 02 Javascript
jQuery内部原理和实现方式浅析
Feb 03 Javascript
javascript+html5实现仿flash滚动播放图片的方法
Apr 27 Javascript
AngularJS中$http使用的简单介绍
Mar 17 Javascript
解决Extjs下拉框不显示的问题
Jun 21 Javascript
JS实现监控微信小程序的原理
Jun 15 Javascript
vue项目创建并引入饿了么elementUI组件的步骤
Apr 11 Javascript
vue webpack重写cookie路径的方法
Jul 10 Javascript
vue相同路由跳转强制刷新该路由组件操作
Aug 05 #Javascript
解决vue路由name同名,路由重复的问题
Aug 05 #Javascript
解决vue项目input输入框双向绑定数据不实时生效问题
Aug 05 #Javascript
Vue 同步异步存值取值实现案例
Aug 05 #Javascript
详解vue路由
Aug 05 #Javascript
解决vue使用vant下拉框van-dropdown-item 绑定title值不变问题
Aug 05 #Javascript
vant 自定义 van-dropdown-item的用法
Aug 05 #Javascript
You might like
一些PHP写的小东西
2006/12/06 PHP
php字符串截取中文截取2,单字节截取模式
2007/12/10 PHP
关于Iframe如何跨域访问Cookie和Session的解决方法
2013/04/15 PHP
WordPress过滤垃圾评论的几种主要方法小结
2016/07/11 PHP
laravel 解决强制跳转 https的问题
2019/10/22 PHP
js 实现打印网页中定义的部分内容的代码
2010/04/01 Javascript
基于jQuery的烟花效果(运动相关)点击屏幕出烟花
2012/06/14 Javascript
jquery中邮箱地址 URL网站地址正则验证实例代码
2013/09/15 Javascript
Jquery节点遍历next与nextAll方法使用示例
2014/07/22 Javascript
Javascript函数的参数
2015/07/16 Javascript
jQuery实现鼠标滑过点击事件音效试听
2015/08/31 Javascript
Bootstrap+jfinal实现省市级联下拉菜单
2016/05/30 Javascript
Angular.js 实现数字转换汉字实例代码
2016/07/14 Javascript
基于JavaScript实现在新的tab页打开url
2016/08/04 Javascript
详解用node.js实现简单的反向代理
2017/06/26 Javascript
本地搭建微信小程序服务器的实现方法
2017/10/27 Javascript
vue.config.js中配置Vue的路径别名的方法
2020/02/11 Javascript
JS面向对象编程基础篇(一) 对象和构造函数实例详解
2020/03/03 Javascript
[44:40]2018DOTA2亚洲邀请赛3月30日 小组赛A组Liquid VS OG
2018/03/31 DOTA
跟老齐学Python之总结参数的传递
2014/10/10 Python
python中的字典使用分享
2016/07/31 Python
python pandas时序处理相关功能详解
2019/07/03 Python
Python datetime包函数简单介绍
2019/08/28 Python
Pyqt5自适应布局实例
2019/12/13 Python
python属于跨平台语言码
2020/06/09 Python
为什么是 Python -m
2020/06/19 Python
selenium设置浏览器为headless无头模式(Chrome和Firefox)
2021/01/08 Python
html5基础教程常用技巧整理
2013/08/20 HTML / CSS
Html5在手机端调用相机的方法实现
2020/05/13 HTML / CSS
软件配置管理有什么好处
2015/04/15 面试题
仓库理货员岗位职责
2013/12/18 职场文书
大学班长的职责
2014/01/27 职场文书
清明节演讲稿
2014/05/27 职场文书
预备党员公开承诺书
2014/05/28 职场文书
旅游与酒店管理专业求职信
2014/07/21 职场文书
浅析MongoDB之安全认证
2021/06/26 MongoDB