VUE调用后台方法

本文详细介绍了如何在Vue项目中配置开发环境,包括修改配置文件、设置API根路径、使用axios进行HTTP请求以及创建和使用API接口的方法。通过具体步骤和代码示例,帮助开发者快速上手。
  • 本次修改dev环境

  • 修改config下index.js文件,添加env: require('./dev.env'),到dev下:
    在这里插入图片描述

  • 修改config下dev.env.js文件,内容如下:

    var merge = require('webpack-merge')
    var prodEnv = require('./prod.env')
    
    module.exports = merge(prodEnv, {
      NODE_ENV: '"development"',
      API_ROOT: '"http://localhost:8081"', //此处是你后台网关或者调用的地址
    })
    
  • 配置src/api/index.js文件(需要自己创建):
    在这里插入图片描述

  • 需要安装axios以继续:npm install --save axios

  • src/api/index.js内容如下:

    import axios from 'axios'
    
    //基地址
    let base = process.env.API_ROOT
    
    
    //通用方法
    export const POST = (url, params) => {
      return axios.post(`${base}${url}`, params).then(res => res.data)
    }
    
    export const GET = (url, params) => {
      return axios.get(`${base}${url}`, {
        params: params
      }).then(res => res.data)
    }
    
    export const PUT = (url, params) => {
      return axios.put(`${base}${url}`, params).then(res => res.data)
    }
    
    export const DELETE = (url, params) => {
      return axios.delete(`${base}${url}`, {
        params: params
      }).then(res => res.data)
    }
    
    export const PATCH = (url, params) => {
      return axios.patch(`${base}${url}`, params).then(res => res.data)
    }
    
    
  • 在api下创建需要连接后台方法的js文件(我这里是api_user.js):
    在这里插入图片描述

  • 内容(按需根据后台方法修改路径),需要传值用list2方法:

    import * as API from './'
    
    export default {
      list: params => {
        return API.POST('/user/test')
      },
      list2: params => {
        return API.POST('/user/test',params)
      },
    }
    
    
  • 页面引入创建的js文件并使用
    在这里插入图片描述

  • 后台方法:
    在这里插入图片描述

  • 效果
    在这里插入图片描述

Vue.js中,调用后台接口并实现数据导出功能通常涉及到两个步骤:发送HTTP请求获取数据以及将数据导出为文件(比如CSV或Excel)。这里是一个简单的示例,假设我们使用axios库来发送GET请求,并且使用js-file-excel库来生成Excel文件: ```html <!-- Vue组件模板 --> <button @click="exportData">导出数据</button> <script> import axios from 'axios'; import { createExcel } from 'js-file-excel'; export default { data() { return { // 假设这是你要导出的数据 dataList: [], }; }, methods: { async exportData() { try { const response = await axios.get('your-api-url'); // 替换为实际的API地址 // 检查数据是否成功获取 if (response.data) { this.dataList = response.data; // 将数据赋值给dataList // 创建Excel文件 const excelData = { sheetNames: ['Sheet1'], // 单元格标签 sheets: { Sheet1: this.dataList, // 数据映射到单元格 }, }; // 导出Excel文件 createExcel(excelData).then((blob) => { const url = URL.createObjectURL(blob); const a = document.createElement('a'); a.href = url; a.download = 'data.xlsx'; // 文件名 a.click(); }); } else { alert('无法获取数据,请检查API'); } } catch (error) { console.error('Error:', error); } }, }, }; </script> ``` 在这个例子中,用户点击"导出数据"按钮时,会触发`exportData`方法。首先发送请求获取数据,如果成功则处理响应并将数据保存到`dataList`,然后创建一个包含这些数据的Excel文件并通过下载链接将其导出。
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值