vue3加axios配合element-plus实现图片等文件本地上传,并获取服务器返回的真实地址数据,前端写法

小白写法嘿嘿

开发工具和关键词

开发工具: 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

<template>
    <div style="width: 80%;">
        <el-form :model="form" label-width="auto" style="max-width: 600px">
            <el-form-item label="标题">
                <el-input v-model="form.bt" />
            </el-form-item>
            <el-upload v-model:file-list="fileList" action="ok" :auto-upload="false" list-type="picture-card"
                :on-preview="handlePictureCardPreview" :on-remove="handleRemove" multiple>
                <el-icon>
                    添加
                    <Plus />
                </el-icon>
            </el-upload>

            <el-dialog v-model="dialogVisible">
                <img w-full :src="dialogImageUrl" alt="Preview Image" />
            </el-dialog>
            <el-form-item>
                <el-button type="primary" @click="onSubmit">新增</el-button>
            </el-form-item>
        </el-form>
    </div>
</template>

<script>
import { ref, reactive } from 'vue'
import axios from 'axios'


const dialogImageUrl = ref('')
const dialogVisible = ref(false)

//这里用了响应式数据
var form = reactive({
    bt: '',
//tp是保存了真实图片地址后的json数组
    tp: '',
})

export default {
    name: 'HomeView',
    data() {
        return {
            form,
            dialogImageUrl,
            dialogVisible,
            fileList: [],
            zh: sessionStorage.getItem('zh')
        }
    },
    methods: {
        async onSubmit() {
            var that = this

            console.log('submit!')
            console.log(this.form);
            if (this.fileList.length == 0) {
                return ElMessage({
                    message: '请先上传图片!',
                    grouping: true,
                    type: 'warning',
                });
            }
            await this.upaction(); // 等待上传图片完成
            console.log("我的上传图片的真实路径", this.fileList);
            var pictureslist = []


            for (let i = 0; i < this.fileList.length; i++) {
                pictureslist.push(this.fileList[i].url)
             
            }

            // 将合并后的数组转换为 JSON 字符串
            var jsonString = JSON.stringify(pictureslist);

            console.log("转换后的 JSON 字符串", jsonString);

            // 将转换后的 JSON 字符串赋值给 this.form.tp
            this.form.tp = jsonString;
            console.log("待上传表单数据", form);
            this.form.zh = this.zh

            // 将表单数据上传服务器
            const res = await axios.post(
                "/api/addproduct", // 请求后端的 URL
                that.form,
                {
                    headers: {
                        "Content-Type": "application/json;charset=utf-8",
                        "Access-Control-Allow-Origin": "*", // 允许所有域名访问,或者设置为特定的域名
                        "Access-Control-Allow-Methods": "GET, POST, OPTIONS", // 允许的请求方法
                        "Access-Control-Allow-Headers": "Content-Type", // 允许的请求头
                    },
                }
            );
            console.log("请求后", res);
            loadingInstance.close()
            ElMessage({
                message: '上传成功!',
                grouping: true,
                type: 'success',
            })

        },
        handlePictureCardPreview(uploadFile) {
            console.log(uploadFile);
            this.dialogImageUrl = uploadFile.url
            this.dialogVisible = true
        },

        handleRemove(file, fileList) {
            console.log(file)
            console.log(fileList)
        },

        // 依次上传图片
        async upaction() {
            var that = this
            for (let i = 0; i < this.fileList.length; i++) {
                var src = await this.uploadFile(this.fileList[i]);
                this.fileList[i].url = src
            }
        },

//保存至服务器后返回真实图片路径地址
        async uploadFile(file) {
            console.log("uploadFile中,未编码url为", file.url);
            const newbasesrc = await this.getdata(file);
            console.log("编码url后", newbasesrc);
            const res = await axios.post(
                "/api/upload", // 请求后端的 URL
                { file: newbasesrc },
                {
                    headers: {
                        "Content-Type": "multipart/form-data;charset=utf-8",
                        "Access-Control-Allow-Origin": "*", // 允许所有域名访问,或者设置为特定的域名
                        "Access-Control-Allow-Methods": "GET, POST, OPTIONS", // 允许的请求方法
                        "Access-Control-Allow-Headers": "Content-Type", // 允许的请求头
                    },
                }
            );
            console.log(res);
            return res.data.fileUrl;
        },

//以下两个自定义函数是为了将input直接获取的file对象转成base64编码格式

        async getdata(file) {
            // 使用 FileReader 将文件转换为 base64 编码字符串
            console.log("getdata函数中,准备转化", file);
            const base64String = await this.readFileAsBase64(file);
            console.log("获得编码", base64String);
            return base64String;
        },

        readFileAsBase64(file) {
            return new Promise((resolve, reject) => {
                const reader = new FileReader();
                reader.onload = (event) => {
                    // 将文件转换为 base64 编码
                    const base64String = event.target.result;
                    resolve(base64String);
                };
                reader.onerror = reject;
                // 读取文件内容并转换为 base64 编码字符串
                reader.readAsDataURL(file.raw);
            });
        },
    }
}
</script>

 如果对您有所帮助,给个小赞赞吧!🌹

  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Vite是一个用于快速构建现代化的Web项目的构建工具,它专注于开发阶段的快速热重载,并使用ES模块作为原生的开发模式。Vue3是Vue.js的最新版本,它在性能、开发体验和可维护性上都有所提升。 针对你提到的具体的库和框架: - Vue Router是Vue.js官方的路由管理器,用于实现页面之间的导航和路由控制。你可以通过npm安装vue-router,并在项目中进行配置和使用。 - Pinia是Vue.js的状态管理库,它提供了一种简单而强大的方式来管理应用程序的状态。你可以集成Pinia到你的Vue项目中,以便更好地组织和共享你的应用程序状态。 - Axios是一个基于Promise的HTTP客户端,用于通过网络发送异步请求。你可以使用Axios来处理与服务器的通信,并获取数据来更新你的Vue应用程序。 - Element Plus是一套基于Vue3的组件库,包含了丰富的UI组件,可以帮助你快速搭建漂亮的用户界面。你可以在项目中安装和使用Element Plus来实现各种交互效果和用户界面。 如果你想使用Vite、Vue3和以上提到的库和框架来创建一个项目,你可以按照以下步骤进行: 1. 安装Vite:通过npm全局安装Vite,然后使用Vite命令初始化一个新的项目。 2. 配置Vite:根据你的项目需求,在Vite的配置文件中添Vue Router、Pinia、AxiosElement Plus的相关配置。 3. 安装和配置Vue Router:通过npm安装Vue Router,并在项目中配置和使用Vue Router来管理应用程序的路由。 4. 集成Pinia:通过npm安装Pinia,并在项目中引入和配置Pinia,以便在应用程序中使用Pinia来管理状态。 5. 使用Axios:通过npm安装Axios,并在项目中引入和配置Axios,以便进行网络请求和数据获取。 6. 引入Element Plus:通过npm安装Element Plus,并在项目中按需引入和使用Element Plus的组件,以搭建漂亮的用户界面。 希望以上信息对你有帮助,祝你在使用Vite、Vue3和这些库和框架时取得成功!<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [vite-vue-ts精简模版集成pinia+svg+router+@src](https://download.csdn.net/download/ldy889/85018930)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* *3* [vite+vue3+ts+vue-router+pinia+axios+element-plus](https://blog.csdn.net/zy_080400/article/details/127125359)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

浩冉学编程

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值