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>
 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值