vue3加axios共同element-plus实现图片等文件本地上传,并获取服务器返回的 ...

打印 上一主题 下一主题

主题 768|帖子 768|积分 2304

小白写法嘿嘿
   开发工具和关键词
  开发工具: vscode
关键词:vue3、element-plus、axios
   后端
  后端业务逻辑处理使用的是unicloud的云函数,大家可以看我上一篇文章。
   思路
  1、克制element-plus的el-upload组件自动上传,变成手动上传,提交表单时候同一处理上传文件
2、此时el-upload组件中的file文件保存到了v-model:file-list="fileList"的fileList的变量中,数据类型类型是file对象的数组
3、提交表单,循环fileList数组,将file数据类型的文件转化成base64编码
4、将子元素为base64编码数据的图片数组依次上传到服务器,并依次获取一个真实的服务器图片地址,并将这些真实地址保存到pictureslist数组
4、后面可以根据自己的代码逻辑处理真实地址的图片数组pictureslist,如:商品多张图片可以将数组转为json格式,保存到数据表中的某一个pictures字段中,后续展示商品直接读取即可
留意:这里不思量文件上传中断和大文件的情况。
   完备代码
   addproduct.vue
  1. <template>
  2.     <div style="width: 80%;">
  3.         <el-form :model="form" label-width="auto" style="max-width: 600px">
  4.             <el-form-item label="标题">
  5.                 <el-input v-model="form.bt" />
  6.             </el-form-item>
  7.             <el-upload v-model:file-list="fileList" action="ok" :auto-upload="false" list-type="picture-card"
  8.                 :on-preview="handlePictureCardPreview" :on-remove="handleRemove" multiple>
  9.                 <el-icon>
  10.                     添加
  11.                     <Plus />
  12.                 </el-icon>
  13.             </el-upload>
  14.             <el-dialog v-model="dialogVisible">
  15.                 <img w-full :src="dialogImageUrl" alt="Preview Image" />
  16.             </el-dialog>
  17.             <el-form-item>
  18.                 <el-button type="primary" @click="onSubmit">新增</el-button>
  19.             </el-form-item>
  20.         </el-form>
  21.     </div>
  22. </template>
  23. <script>
  24. import { ref, reactive } from 'vue'
  25. import axios from 'axios'
  26. const dialogImageUrl = ref('')
  27. const dialogVisible = ref(false)
  28. //这里用了响应式数据
  29. var form = reactive({
  30.     bt: '',
  31. //tp是保存了真实图片地址后的json数组
  32.     tp: '',
  33. })
  34. export default {
  35.     name: 'HomeView',
  36.     data() {
  37.         return {
  38.             form,
  39.             dialogImageUrl,
  40.             dialogVisible,
  41.             fileList: [],
  42.             zh: sessionStorage.getItem('zh')
  43.         }
  44.     },
  45.     methods: {
  46.         async onSubmit() {
  47.             var that = this
  48.             console.log('submit!')
  49.             console.log(this.form);
  50.             if (this.fileList.length == 0) {
  51.                 return ElMessage({
  52.                     message: '请先上传图片!',
  53.                     grouping: true,
  54.                     type: 'warning',
  55.                 });
  56.             }
  57.             await this.upaction(); // 等待上传图片完成
  58.             console.log("我的上传图片的真实路径", this.fileList);
  59.             var pictureslist = []
  60.             for (let i = 0; i < this.fileList.length; i++) {
  61.                 pictureslist.push(this.fileList[i].url)
  62.             
  63.             }
  64.             // 将合并后的数组转换为 JSON 字符串
  65.             var jsonString = JSON.stringify(pictureslist);
  66.             console.log("转换后的 JSON 字符串", jsonString);
  67.             // 将转换后的 JSON 字符串赋值给 this.form.tp
  68.             this.form.tp = jsonString;
  69.             console.log("待上传表单数据", form);
  70.             this.form.zh = this.zh
  71.             // 将表单数据上传服务器
  72.             const res = await axios.post(
  73.                 "/api/addproduct", // 请求后端的 URL
  74.                 that.form,
  75.                 {
  76.                     headers: {
  77.                         "Content-Type": "application/json;charset=utf-8",
  78.                         "Access-Control-Allow-Origin": "*", // 允许所有域名访问,或者设置为特定的域名
  79.                         "Access-Control-Allow-Methods": "GET, POST, OPTIONS", // 允许的请求方法
  80.                         "Access-Control-Allow-Headers": "Content-Type", // 允许的请求头
  81.                     },
  82.                 }
  83.             );
  84.             console.log("请求后", res);
  85.             loadingInstance.close()
  86.             ElMessage({
  87.                 message: '上传成功!',
  88.                 grouping: true,
  89.                 type: 'success',
  90.             })
  91.         },
  92.         handlePictureCardPreview(uploadFile) {
  93.             console.log(uploadFile);
  94.             this.dialogImageUrl = uploadFile.url
  95.             this.dialogVisible = true
  96.         },
  97.         handleRemove(file, fileList) {
  98.             console.log(file)
  99.             console.log(fileList)
  100.         },
  101.         // 依次上传图片
  102.         async upaction() {
  103.             var that = this
  104.             for (let i = 0; i < this.fileList.length; i++) {
  105.                 var src = await this.uploadFile(this.fileList[i]);
  106.                 this.fileList[i].url = src
  107.             }
  108.         },
  109. //保存至服务器后返回真实图片路径地址
  110.         async uploadFile(file) {
  111.             console.log("uploadFile中,未编码url为", file.url);
  112.             const newbasesrc = await this.getdata(file);
  113.             console.log("编码url后", newbasesrc);
  114.             const res = await axios.post(
  115.                 "/api/upload", // 请求后端的 URL
  116.                 { file: newbasesrc },
  117.                 {
  118.                     headers: {
  119.                         "Content-Type": "multipart/form-data;charset=utf-8",
  120.                         "Access-Control-Allow-Origin": "*", // 允许所有域名访问,或者设置为特定的域名
  121.                         "Access-Control-Allow-Methods": "GET, POST, OPTIONS", // 允许的请求方法
  122.                         "Access-Control-Allow-Headers": "Content-Type", // 允许的请求头
  123.                     },
  124.                 }
  125.             );
  126.             console.log(res);
  127.             return res.data.fileUrl;
  128.         },
  129. //以下两个自定义函数是为了将input直接获取的file对象转成base64编码格式
  130.         async getdata(file) {
  131.             // 使用 FileReader 将文件转换为 base64 编码字符串
  132.             console.log("getdata函数中,准备转化", file);
  133.             const base64String = await this.readFileAsBase64(file);
  134.             console.log("获得编码", base64String);
  135.             return base64String;
  136.         },
  137.         readFileAsBase64(file) {
  138.             return new Promise((resolve, reject) => {
  139.                 const reader = new FileReader();
  140.                 reader.onload = (event) => {
  141.                     // 将文件转换为 base64 编码
  142.                     const base64String = event.target.result;
  143.                     resolve(base64String);
  144.                 };
  145.                 reader.onerror = reject;
  146.                 // 读取文件内容并转换为 base64 编码字符串
  147.                 reader.readAsDataURL(file.raw);
  148.             });
  149.         },
  150.     }
  151. }
  152. </script>
复制代码
 假如对您有所资助,给个小赞赞吧!
回复

使用道具 举报

0 个回复

正序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

温锦文欧普厨电及净水器总代理

金牌会员
这个人很懒什么都没写!

标签云

快速回复 返回顶部 返回列表