Mrcdh技术博客 Mrcdh技术博客
首页
  • Html5
  • Javascript
  • Nodejs
  • electron
  • Android
  • 微信公众号
  • 框架
  • 其他
  • Mysql
  • PHP
  • Python
  • java
  • Gulp
  • 其它
  • 网站
  • 资源
  • 分类
  • 标签
  • 归档
GitHub (opens new window)

Mrcdh

全栈开发小学生
首页
  • Html5
  • Javascript
  • Nodejs
  • electron
  • Android
  • 微信公众号
  • 框架
  • 其他
  • Mysql
  • PHP
  • Python
  • java
  • Gulp
  • 其它
  • 网站
  • 资源
  • 分类
  • 标签
  • 归档
GitHub (opens new window)
  • element-ui

    • 基于 VUE 和 element-ui 的树形穿梭框组件 el-tree-transfer
    • element-ui常见问题
  • vue3

  • vue实现图片文件的显示和上传
  • composition-api
  • vue常用eslint配置模板
  • vue.config.js常用配置
  • vuepress-theme-vdoing本站使用主题
  • vue常见问题
  • 常用插件

  • 《Vuejs》
mrcdh
2020-10-23

vue实现图片文件的显示和上传

# vue实现图片文件的显示和上传

<template>
  <div>
    <button @click="selectFile">选择图片</button>
    <img :src="img" v-show="img">
    <input type="file" ref="file" style="display:none;" @change="fileChange">
  </div>
</template>

<script>
export default {
  data() {
    return {
      img: ''
    }
  },
  methods: {
    // 选择文件
    selectFile(){
      this.$refs.file.click()
    },
    // 文件选择后触发
    fileChange(e){
      // 通过DOM取文件数据
      const file = this.$refs.file.files[0]
      // 计算文件大小 KB
      const size = Math.floor(file.size / 1024)
      // 显示本地图片
      this.img = window.URL.createObjectURL(file)

      // 使用 FormData 构建表单数据
      const formData = new FormData()
      formData.append('file', file)
      // 这里使用 axios 上传文件
      this.$axios.post('common/upload', formData, {
        headers: {
          'Content-Type': 'multipart/form-data'
        }
      }).then(res => {
        // ...
      })

      // 显示上传进度
      /*this.$axios({
        method: 'post',
        url: 'common/upload',
        data: formData,
        headers: { 'Content-Type': 'multipart/form-data' },
        onUploadProgress(progressEvent){
            if (progressEvent.lengthComputable) {
                let val = (progressEvent.loaded / progressEvent.total * 100).toFixed(0);
                // ...
            }
        }
        })*/
    }
  },
}
</script>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
#vue
上次更新: 2023/09/22, 16:54:32
Vue3使用Typescript常见问题
composition-api

← Vue3使用Typescript常见问题 composition-api→

最近更新
01
uniapp常见问题
03-19
02
Vue3项目搭建
12-25
03
使用pnpm的monorepo组织项目
11-01
更多文章>
Theme by Vdoing | Copyright © 2020-2025 Mrcdh | 苏ICP备2020058908号-1
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式
×