element-plus实现图片上传

19 篇文章 0 订阅
6 篇文章 0 订阅
<el-form-item label="头像" label-width="80px">
             <el-upload
                class="avatar-uploader"
                :action="`${path}/fileUploadAndDownload/upload`"
                :headers="{ 'x-token': userStore.token }"
                :show-file-list="false"
                :on-success="uploadSuccess"
                :on-error="uploadError"
                v-model="userInfo.headerImg"
              >
                <img v-if="userInfo.headerImg" :src="imageUrl" class="avatar" />
                <el-icon v-else class="avatar-uploader-icon"><Plus /></el-icon>
             </el-upload>
</el-form-item>

这里action是api的路径,headers是token

2.在script中写成功的回调以及失败的回调函数,代码如下

// 图片上传成功的函数
const uploadSuccess = (res, upload)=> {
  console.log(res)
      if (res.code === 0) {
        ElMessage({
          type: 'success',
          message: '上传成功'
        })
        imageUrl.value = URL.createObjectURL(upload.raw)
        userInfo.value.headerImg = res.data.file.url
      } else {
        ElMessage({
          type: 'warning',
          message: res.msg
        })
      }
}
//图片上传失败的回调
const uploadError = ()=> {
      ElMessage({
        type: 'error',
        message:'上传失败'
      })
}

3.数据的声明

const userInfo = ref({
  headerImg: '',
})
  • 3
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
你可以使用 element-plus 提供的 Upload 组件来实现上传图片文件的功能。首先,你需要在项目中安装 element-plus: ``` npm install element-plus --save ``` 然后,在你的代码中引入需要的组件和样式: ```javascript import { createApp } from 'vue'; import ElementPlus from 'element-plus'; import 'element-plus/lib/theme-chalk/index.css'; const app = createApp(App); app.use(ElementPlus); app.mount('#app'); ``` 接下来,你可以在你的模板中使用 Upload 组件来实现上传图片文件的功能,例如: ```html <template> <el-upload class="upload-demo" action="/your-upload-url" :auto-upload="false" :on-change="handleChange" > <el-button slot="trigger" size="small" type="primary">点击上传</el-button> <div slot="tip" class="upload-demo-tip">只能上传jpg/png文件,且不超过2MB</div> </el-upload> </template> <script> export default { methods: { handleChange(file) { // 处理文件变化事件 console.log(file); } } }; </script> ``` 在上面的代码中,你需要根据实际情况修改 `action` 属性的值为你的上传接口地址。`auto-upload` 属性设置为 `false` 表示手动触发上传,你可以根据需求设置为 `true` 来自动上传。 另外,在 `handleChange` 方法中,你可以处理文件变化事件,例如打印上传的文件信息、调用接口进行文件上传等。 以上是使用 element-plus 实现上传图片文件的基本步骤,你可以根据自己的需求进行更详细的配置和处理。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值