[toc]
### 1.实现点击复选框展示对应的操作按钮
```
//index.vue
computed : {
checkList(){
return this.list.filter(item=>item.checked)
},
checkedAllStatus(){
return this.checkList.length === this.list.length
},
//根据选中的复选框个数控制操作按钮
checkedCount(){
return this.checkList.length
}
}
<div class="d-flex top-button align-items-center">
<Button type="primary" icon="ios-search" class="mr-2">上传</Button>
<Button icon="ios-search" class="mr-2">新建文件夹</Button>
<Button icon="ios-search" v-if="checkedCount" class="mr-2">下载</Button>
<Button icon="ios-search" v-if="checkedCount == 1" class="mr-2">分享</Button>
<Button icon="ios-search" v-if="checkedCount == 1" class="mr-2">重命名</Button>
<Button icon="ios-search" v-if="checkedCount" class="mr-2">删除</Button>
<Input class="ml-auto top-search" search enter-button placeholder="请输入关键词" />
</div>
```
### 2. 实现重名名功能
```
//media-list.vue
<DropdownItem @click.native="rename">重命名</DropdownItem>
//重命名
rename() {
this.value = this.item.name
this.$Modal.confirm({
render: (h) => {
return h('Input', {
props: {
value: this.value,
autofocus: true,
placeholder: '请填写新名称...'
},
on: {
input: (val) => {
console.log(val)
this.value = val;
}
}
})
},
onOk : ()=>{
this.$emit("on-event",{
type : "rename",
index: this.index,
value : this.value
})
}
})
}
//index.vue
handleEvent(e) {
console.log(e.value)
switch (e.type) {
case "delete":
this.list.splice(e.index, 1);
this.$Message.success("删除成功")
break;
case "checked":
this.list[e.index].checked = e.value
break;
case "rename" :
this.list[e.index].name = e.value
default:
break;
}
},
```
### 3. 点击操作的重命名按钮,实现文件重命名功能(对上一个重命名功能优化)
```
//media-list.vue
//重命名
rename() {
this.$emit("on-event",{
type : "rename",
index: this.index
})
}
//index.vue
<Button icon="ios-search" @click="rename(false)" v-if="checkedCount == 1" class="mr-2">重命名</Button>
//重命名
rename(index = false){
let item = index !==false ?this.list[index] : this.checkList[0]
let value = item.name
this.$Modal.confirm({
render: (h) => {
return h('Input', {
props: {
value: value,
autofocus: true,
placeholder: '请填写新名称...'
},
on: {
input: (val) => {
value= val;
}
}
})
},
onOk : ()=>{
item.name = value
}
})
}
handleEvent(e) {
console.log(e.value)
switch (e.type) {
case "delete":
this.list.splice(e.index, 1);
this.$Message.success("删除成功")
break;
case "checked":
this.list[e.index].checked = e.value
break;
case "rename" :
this.rename(e.index)
default:
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端部分