[toc]
### 1. 安裝v-viewer插件
```
npm install v-viewer --save
```
### 2. 在main.js文件內引入v-viewer
```
import 'viewerjs/dist/viewer.css'
import Viewer from 'v-viewer'
import Vue from 'vue'
Vue.use(Viewer)
```
### 3. 使用v-viewer插件實現圖片的預覽功能
```
//index.vue
<div class="d-none images" v-viewer>
<img v-for="(src,index) in images" :src="src" :key="index">
</div>
//data里面定義images
images : ["https://tangzhe123-com.oss-cn-shenzhen.aliyuncs.com/Appstatic/qsbk/demo/datapic/1.jpg","https://tangzhe123-com.oss-cn-shenzhen.aliyuncs.com/Appstatic/qsbk/demo/datapic/2.jpg"],
//media-list.vue
<div class="border-bottom px-3 py-2 file-list" @click="clickEvent">
clickEvent(){
this.$emit("on-event",{
type : "image",
url: this.item.url
})
}
//index.vue
case "image" :
const viewer = this.$el.querySelector('.images').$viewer
viewer.show()
break;
```
### 4.判斷如果點擊的是圖片才能調用圖片預覽方法
```
//media-list.vue
clickEvent(){
if(this.item.type === "image"){
this.$emit("on-event",{
type : "image",
url: this.item.url
})
}
}
```
### 5. 實現點擊預覽對應的圖片
```
//index.vue
//刪除原來data里面定義images
computed: {
images(){
let urls = [];
this.list.forEach((item,index)=>{
if(item.type === "image"){
urls.push(item.url)
}
})
return urls;
},
checkList() {
return this.list.filter(item => item.checked)
},
checkedAllStatus() {
return this.checkList.length === this.list.length
},
checkedCount() {
return this.checkList.length
}
},
case "image" :
const viewer = this.$el.querySelector('.images').$viewer
let index =this.images.findIndex(url=>url === e.url)
viewer.view(index)
viewer.show()
break;
```
- 第一章 VUE-CLI+IVIEW進行項目初始化
- 1.1 使用vue-cli4創建項目
- 1.2 引入iview組件庫
- 1.3 引入bootstrap4和圖標庫
- 1.4 安裝和配置vue-router
- 第二章 pc端登錄頁開發
- 2.1 pc端登錄頁開發(一)
- 2.2 pc端登錄頁開發(二)
- 2.3 pc端登錄頁開發(三)
- 第三章 pc端全局布局開發
- 3.1 pc端全局布局開發(一)
- 3.2 pc端全局布局開發(二) 頂部導航
- 第四章 pc端側邊欄開發
- 4.1 pc端側邊欄開發(一) 菜單
- 4.2 pc端側邊欄開發(二) 容量提示
- 第五章 pc端文件列表開發
- 5.1 pc端文件列表開發(一) 操作條
- 5.2 pc端文件列表開發(二) 列表(1)
- 5.3 pc端文件列表開發(三) 列表(2)
- 第六章 封裝多功能文件列表組件
- 6.1 封裝文件列表組件(一)
- 6.2 封裝文件列表組件(二) 刪除
- 6.3 封裝文件列表組件(三) 多選操作
- 6.4 封裝文件列表組件(四) 重命名
- 6.5 封裝文件列表組件(五) 圖片預覽
- 第七章 前端數據交互開發
- 7.1 pc端交互-引入axios和vuex
- 7.2 pc端交互-注冊登錄
- 7.3 pc端交互-初始化和退出登錄
- 7.4 pc端交互-攔截器完善
- 7.5 權限驗證
- 7.6 pc端交互-獲取文件列表
- 7.7 pc端交互-創建文件夾
- 7.8 上傳文件
- 7.9 pc端交互-文件重命名
- 7.10 pc端交互-批量刪除
- 7.11 pc端交互-搜索文件
- 7.12 pc端交互-切換目錄
- 7.13 pc端交互-優化體驗和篩選類型
- 7.14 pc端交互-下載文件
- 7.15 pc端交互-生成分享鏈接
- 7.16 pc端交互-我的分享列表
- 7.17 pc端交互-查看分享
- 7.18 pc端交互-保存我的網盤
- 第八章 項目打包與部署
- 8.1 部署前環境搭建
- 8.2 部署pc端部分