网站首页 > 技术文章 正文
点击右上方红色按钮关注“web秀”,让你真正秀起来
前言
有了前面的代码,这次添加图片附件就非常简单了,这里就写个简单的示例,后面优化样式等。
GitHub - javanf/todo-list: 待办任务管理
本次《todo list: Vue待办事项任务管理》,分为一下章节,有兴趣的同学可以持续关注。
第一章: 初识(项目搭建、基本功能组件实现)
第二章: 数据动态化处理(localStorage + Vuex),可新增,可编辑
第三章:待办事项自定义分组
第四章:待办事项添加描述图片等信息
第五章:可线上操作,入库Mysql
第六章:多人协同处理待办事项,权限管理
第七章:完结:线上发布
初步定义7个章节,实际开发中有可能有所增减。
html页面调整
1、input type=file选择文件
2、通过@change监听input框的改变事件,获取图片文件
<c-dialog ... > <div class="item-detail"> <ul> ... <!--添加附件上传按钮和预览--> <li class="dis-flex"> <div class="w-80">附件</div> <div class="flex1"> <img class="img-pre" :src="img" @click="preview(img)" v-for="img in listItem.imgs"> <input type="file" @change="fileChange" /> </div> </li> </ul> </div> </c-dialog> <!--预览附件大图弹框--> <c-dialog ref="previewImg" title="" cancelBtn="" confirmBtn="" > <div class="preview-img"> <img class="img-pre" :src="previewImg"> </div> </c-dialog>
对应JS事件
1、监听input file框改变,获取图片后将文件转换成base64格式的字符串(用于图片预览)
2、将值push到任务里面的imgs数组,可以直接存储起来
3、点击图片通过弹框来预览大图片
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() } } }
预览图
总结
本章节的重点就是将文件转换成base64来预览,当然这个主意是size比较小的图片,如果是大图片还是通过上传到服务器的方式,否则base64的字符串会非常的大。
GitHub - javanf/todo-list: 待办任务管理
公告
喜欢小编的点击关注,了解更多知识!
源码地址,可以点击下方“了解更多”获取!
- 上一篇: Html5 上传图片 移动端、PC端通用
- 下一篇: 从一道面试题说起:GET 请求能传图片吗?
猜你喜欢
- 2024-10-10 让编辑器支持word的复制黏贴,支持截屏的黏贴
- 2024-10-10 大文件上传优化(切片、断点续传、秒传)
- 2024-10-10 你知道前端对图片的处理方式吗(前端实现图片编辑)
- 2024-10-10 JavaScript异步图像上传(javascript 异步操作)
- 2024-10-10 javascript对文件和进制操作的一些方法汇总
- 2024-10-10 Node + H5 实现大文件分片上传、断点续传
- 2024-10-10 input上传图片并压缩(vue,前端,js)
- 2024-10-10 leaflet地图截图批量导出(leaflet地图旋转)
- 2024-10-10 Spring WebSocket传递多媒体消息(websocket springmvc)
- 2024-10-10 JS上传文件判断文件类型(js如何判断文件是否存在)
- 02-21走进git时代, 你该怎么玩?_gits
- 02-21GitHub是什么?它可不仅仅是云中的Git版本控制器
- 02-21Git常用操作总结_git基本用法
- 02-21为什么互联网巨头使用Git而放弃SVN?(含核心命令与原理)
- 02-21Git 高级用法,喜欢就拿去用_git基本用法
- 02-21Git常用命令和Git团队使用规范指南
- 02-21总结几个常用的Git命令的使用方法
- 02-21Git工作原理和常用指令_git原理详解
- 最近发表
- 标签列表
-
- cmd/c (57)
- c++中::是什么意思 (57)
- sqlset (59)
- ps可以打开pdf格式吗 (58)
- phprequire_once (61)
- localstorage.removeitem (74)
- routermode (59)
- vector线程安全吗 (70)
- & (66)
- java (73)
- org.redisson (64)
- log.warn (60)
- cannotinstantiatethetype (62)
- js数组插入 (83)
- resttemplateokhttp (59)
- gormwherein (64)
- linux删除一个文件夹 (65)
- mac安装java (72)
- reader.onload (61)
- outofmemoryerror是什么意思 (64)
- flask文件上传 (63)
- eacces (67)
- 查看mysql是否启动 (70)
- java是值传递还是引用传递 (58)
- 无效的列索引 (74)