前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Todo List: 待办事项添加描述图片等信息(file转base64存储) – 第四章

Todo List: 待办事项添加描述图片等信息(file转base64存储) – 第四章

作者头像
Javanx
发布2019-09-04 16:44:44
5650
发布2019-09-04 16:44:44
举报
文章被收录于专栏:web秀web秀

前言

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

Todo List GitHub代码库

Todo List: 待办事项添加描述图片等信息(file转base64存储) - 第四章
Todo List: 待办事项添加描述图片等信息(file转base64存储) - 第四章

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

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

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

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

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

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

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

第七章:完结:线上发布

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

html页面调整

1、input type=file选择文件

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

代码语言:javascript
复制
<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>
Todo List: 待办事项添加描述图片等信息(file转base64存储) - 第四章
Todo List: 待办事项添加描述图片等信息(file转base64存储) - 第四章

对应JS事件

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

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

Todo List: 待办事项添加描述图片等信息(file转base64存储) - 第四章
Todo List: 待办事项添加描述图片等信息(file转base64存储) - 第四章

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

Todo List: 待办事项添加描述图片等信息(file转base64存储) - 第四章
Todo List: 待办事项添加描述图片等信息(file转base64存储) - 第四章
代码语言:javascript
复制
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()
    }
  }
}

预览图

Todo List: 待办事项添加描述图片等信息(file转base64存储) - 第四章
Todo List: 待办事项添加描述图片等信息(file转base64存储) - 第四章

总结

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

Todo List GitHub代码库

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2019年5月29日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 前言
  • html页面调整
  • 对应JS事件
  • 预览图
  • 总结
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档