当前位置: 首页 > news >正文

宣传片制作公司南京广州seo排名外包

宣传片制作公司南京,广州seo排名外包,商标设计网上接单 平台,dw做网站一般设为什么样技术栈:Vue3 Ts Element-plus 官网地址:Upload 上传 | Element Plus 一、背景: 表单上传图片功能 二、效果: 三、流程: ①点击上传图片按钮,系统弹出文件选择对话框,选择图片并确认 ②调…

技术栈:Vue3 + Ts + Element-plus

官网地址:Upload 上传 | Element Plus

一、背景:

表单上传图片功能

二、效果:

三、流程:

点击上传图片按钮,系统弹出文件选择对话框,选择图片并确认

②调用上传接口

③接口将成功上传的图片链接返回给管理台,管理台将接收的图片链接保存到表单中

④提交表单

四、具体实现:

①书写API

//引入二次封装的axios
import request from "@/utils/request";enum API {//上传图片接口UPLOAD_URL = '/saas-api/station/upload'
}
// 对外导出上传图片的接口
export const reqUpload = (file:any) => {// 创建了一个新的 FormData 对象,用于构建表单数据,并将file添加到FormData对象中const formData = new FormData();formData.append('file', file);return request.post(API.UPLOAD_URL, formData);
};

 备注:官网中upload组件中action是可以直接写请求 URL,因为我在请求头中添加了租户id和token,如果直接将URL写入action中会报错‘‘缺少租户id’’,所有利用axios请求URL

②具体业务实现

<el-form><el-form-item label="图片" prop="imageUrl"><el-upload class="avatar-uploader" :show-file-list="false" :on-success="handleAvatarSuccess" :before-upload="beforeAvatarUpload"><img v-if="chargeForm.imageUrl" :src="chargeForm.imageUrl" class="avatar" /><el-icon v-else class="avatar-uploader-icon"><Plus /></el-icon></el-upload></el-form-item>
</el-form><script setup lang="ts">
import { ref,reactive } from 'vue'
import {  reqUpload } from '@/api/device/station/index.ts'//信息的收集
let chargeForm = reactive({imageUrl: '',
})//图片上传成功的钩子
const handleAvatarSuccess: UploadProps['onSuccess'] = () => {//图片上传成功,清除掉对应图片校验结果chargeFormRef.value.clearValidate('imageUrl')
}
//上传图片组件->上传图片之前触发的钩子函数
const beforeAvatarUpload: UploadProps['beforeUpload'] = async (rawFile: any) => {//请求上传文件的接口let res = await reqUpload(rawFile)//将接口的地址赋值给表单并呈现chargeForm.imageUrl = res.data.url//上传图片格式和大小要求  png|jpg  4Mif (rawFile.type !== 'image/png' || rawFile.type == 'image/jpg') {ElMessage.error('上传文件格式务必PNG|JPG')return false} else if (rawFile.size / 1024 / 1024 > 4) {ElMessage.error('上传文件大小小于4M')return false}// 取消默认的上传请求return false
}
</script><style scoped>
.avatar-uploader .avatar {width: 178px;height: 178px;display: block;
}
</style><style>
.avatar-uploader .el-upload {border: 1px dashed var(--el-border-color);border-radius: 6px;cursor: pointer;position: relative;overflow: hidden;transition: var(--el-transition-duration-fast);
}.avatar-uploader .el-upload:hover {border-color: var(--el-color-primary);
}.el-icon.avatar-uploader-icon {font-size: 28px;color: #8c939d;width: 178px;height: 178px;text-align: center;
}
</style>

说明:

before-upload事件是上传文件之前的钩子,rawFile参数为上传的文件

点击上传图片时,请求后端接口(接口为封装好的reqUpload函数),将选中的文件作为接口的参数

具体实现在👉beforeAvatarUpload函数中

③遇到的问题

问题:

上传图片的接口是正常的,但出现一个localhost的请求报错

分析:

这个错误主要是出现在el-upload 组件的配置上。该组件在上传之前会触发 beforeAvatarUpload 函数,但是该函数内部的操作会导致额外的请求发送到 http://localhost:5173/,从而导致 404 错误。

解决:

在beforeAvatarUpload 的回调函数返回 false 来取消默认的上传请求。

 

http://www.ds6.com.cn/news/112091.html

相关文章:

  • 潍坊做网站哪家好营销策划书案例
  • seo交互论坛专业培训seo的机构
  • 银行做网站视频南宁网络推广品牌
  • 福州网站建设liedns刷百度关键词排名
  • 公司网站建设需要什么资质上海哪家优化公司好
  • wordpress默认长沙网站seo分析
  • 购物网站建设机构重庆最新数据消息
  • 用云速成美站怎么做网站全网品牌推广公司
  • 阿里云虚拟主机做网站淘宝关键词排名查询工具免费
  • 手机版网站建设合同网页设计与制作
  • 网站设计人员国内搜索引擎排名2022
  • 商城建站服务网站推广技巧
  • 网站做多少外链seo建站平台哪家好
  • WordPress开cdn支付谷歌优化推广
  • 定远县建设局网站百度开户是什么意思
  • 电影网站如何做不侵权营销外包公司
  • 徐汇微信手机网站制作怎么推广自己的店铺
  • 城市建设网站的项目背景seo快速排名软件网站
  • 网络水果有哪些网站可以做中国建设网官方网站
  • 上海专业网站建设排行怎么推广网站链接
  • 家政网站设计怎么卸载windows优化大师
  • biz网站后缀十大新媒体平台有哪些
  • 怀柔区企业网站设计机构提供天津seo推广优化
  • namesilo wordpress怎么做网站优化排名
  • 深圳企业高端网站建设南宁网站seo排名优化
  • 如何安装wordpress软件seo和sem的区别是什么?
  • 网站建设公司南宁今日国内重大新闻事件
  • 医院网站前置审批最快多久出来怎么在百度上投放广告
  • 做茶叶网站上海企业优化
  • 物联网平台功能成都seo学徒