前端实现图片的上传

本文介绍了两种前端实现图片上传的方法。首先通过Element-UI组件库,利用`el-upload`设置action地址及headers参数,实现图片上传并展示在页面上。其次,探讨了使用H5的上传功能来完成相同任务。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、使用element-ui

代码如下:

<el-upload
  class="avatar-uploader"
  action="https://jsonplaceholder.typicode.com/posts/"
  :show-file-list="false"
  :on-success="handleAvatarSuccess"
  :before-upload="beforeAvatarUpload">
  <img v-if="imageUrl" :src="imageUrl" class="avatar">
  <i v-else class="el-icon-plus avatar-uploader-icon"></i>
</el-upload>

<style>
  .avatar-uploader .el-upload {
    border: 1px dashed #d9d9d9;
    border-radius: 6px;
    cursor: pointer;
    position: relative;
    overflow: hidden;
  }
  .avatar-uploader .el-upload:hover {
    border-color: #409EFF;
  }
  .avatar-uploader-icon {
    font-size: 28px;
    color: #8c939d;
    width: 178px;
    height: 178px;
    line-height: 178px;
    text-align: center;
  }
  .avatar {
    width: 178px;
    height: 178px;
    display: block;
  }
</style>

<script>
  export default {
    data() {
      return {
        imageUrl: ''
      };
    },
    methods: {
      handleAvatarSuccess(res, file) {
        this.imageUrl = URL.createObjectURL(file.raw);
      },
      beforeAvatarUpload(file) {
        const isJPG = file.type === 'image/jpeg';
        const isLt2M = file.size / 1024 / 1024 < 2;

        if (!isJPG) {
          this.$message.error('上传头像图片只能是 JPG 格式!');
        }
        if (!isLt2M) {
          this.$message.error('上传头像图片大小不能超过 2MB!');
        }
        return isJPG && isLt2M;
      }
    }
  }
</script>

上述action是提交图片的地址,若需要穿参数可以使用el-upload的属性headers,然后就可以了,下面会拿到imageUrl,然后绑定在页面,显示在页面上,就完成了图片上传的功能。

二、利用H5上传图片

<template>
    <div class="phone" for="upload" :class="{'card': useCategory === '3'}">
        <input type="file" id="upload" accept="image/*" @change="openPhone" style="opacity:0;">
        <img :src="headerImage" class="picture" alt="">
    </div>
</template>

<script>
    export default {
        name: 'phone',
        props: {
            useCategory: '',
            onThree: false,
            isFlag: false
        },
        data() {
            return {
                icValue: '',
                ocrResult: {},
                headerImage: '',
            }
        },
        methods: {
            openPhone(e) {
                if(!this.isFlag){
                    let files = e.target.files || e.dataTransfer.files
                    if (!files.length) return
                    this.picValue = files[0]
                    this.imgPreview(this.picValue)
                }
            },
            imgPreview(file) {
                let self = this
                let Orientation
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值