1. 程式人生 > 程式設計 >Vue基於iview table展示圖片實現點選放大

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="Vue基於iview table展示圖片實現點選放大">
     </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',[
        h('viewer',{
          props:{
            images:photo
          }
        },[
          h('img',{
            attrs: {
              src:photo[0],style: 'width: 22px;margin-right:5px'
            },})
        ])
      ])
    );
    return h('div',devicesArr);
  }
}

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支援我們。