点击右上方红色按钮关注“web秀”,让你真正秀起来

前言

有了前面的代码,这次添加图片附件就非常简单了,这里就写个简单的示例,后面优化样式等。

GitHub - javanf/todo-list: 待办任务管理

6b736689b3014bb24654827a03836604.png

本次《todo list: Vue待办事项任务管理》,分为一下章节,有兴趣的同学可以持续关注。

第一章: 初识(项目搭建、基本功能组件实现)

第二章: 数据动态化处理(localStorage + Vuex),可新增,可编辑

第三章:待办事项自定义分组

第四章:待办事项添加描述图片等信息

第五章:可线上操作,入库Mysql

第六章:多人协同处理待办事项,权限管理

第七章:完结:线上发布

初步定义7个章节,实际开发中有可能有所增减。

html页面调整

1、input type=file选择文件

2、通过@change监听input框的改变事件,获取图片文件

...
附件
7c7a192ec49f28ecc398f04be3aeaeb7.png
67c2e4cd7531309f59d6d9159fd2f022.png

对应JS事件

1、监听input file框改变,获取图片后将文件转换成base64格式的字符串(用于图片预览)

2、将值push到任务里面的imgs数组,可以直接存储起来

d92e50c63d04166f36283d7137e9796a.png

3、点击图片通过弹框来预览大图片

563c2be43cea125d96948e7bd0d367f5.png
methods: { preview (img) { this.previewImg = img this.$refs.previewImg.show() }, fileChange (e) { let vm = this // input 改变事件 let file = e.target.files[0] console.log(file) // 文件转base64 var reader = new FileReader() reader.readAsDataURL(file) reader.onload = function (e) { console.log(reader.result) vm.listItem.imgs.push(reader.result) } }, ... addItem (index) { this.groupIndex = index this.listItem = { name: '', description: '', level: 0, imgs: [] // 添加空的数组 } this.$refs.itemDetail.show() } }}
0243d5f585ee32c883df96758a1543a1.png

预览图

22bfe8f2d03487a4d3bb0f7edc0a8351.png

总结

本章节的重点就是将文件转换成base64来预览,当然这个主意是size比较小的图片,如果是大图片还是通过上传到服务器的方式,否则base64的字符串会非常的大。

GitHub - javanf/todo-list: 待办任务管理

公告

喜欢小编的点击关注,了解更多知识!

源码地址,可以点击下方“了解更多”获取!

Logo

开放原子开发者工作坊旨在鼓励更多人参与开源活动,与志同道合的开发者们相互交流开发经验、分享开发心得、获取前沿技术趋势。工作坊有多种形式的开发者活动,如meetup、训练营等,主打技术交流,干货满满,真诚地邀请各位开发者共同参与!

更多推荐