基于Vite+Vue3 给项目引入Axios

基于Vite+Vue3 给项目引入Axios,方便与后端进行通信。

系列文章指路👉

系列文章-基于Vue3创建前端项目并引入、配置常用的库和工具类

文章目录

安装依赖

npm install axios

新建src/config/config.js 用于存放常用配置

javascript 复制代码
const config = {
   baseUrl: '/boot-test'
}

export default config

进行简单封装

引用阶段先简单封装,后续有复杂功能添加进来再进行改造。

src目录下,新建utils,axios两个文件夹,新建index.js

javascript 复制代码
import axios from 'axios'
import config from "@/config/config.js";

const http = axios.create()
http.defaults.baseURL = config.baseUrl
http.defaults.timeout = 15 * 1000
http.defaults.headers.common['Content-Type'] = 'application/json;charset=UTF-8'

export default http

解决跨域问题

复用我们之前的后端项目,作为Vue3的后端:系列文章-基于SpringBoot3创建项目并配置常用的工具和一些常用的类

需要解决跨域问题,前后端解决都可以,我们本次采用前端解决。

javascript 复制代码
    server: {
        open: true,// 启动项目自动弹出浏览器
        port: 4000,// 启动端口
        proxy: {
            '/boot-test': {
                target: 'http://localhost:8001/boot-test',	// 实际请求地址
                changeOrigin: true,
                rewrite: (path) => path.replace(/^\/boot-test/, '')
            },
        }
    },

调用尝试

写个小demo,把后端请求到的水果列表展示到前端表格上。

html 复制代码
<template>
  <h3>
    展示水果列表
  </h3>
  <div style="width: 1000px;">
    <a-table bordered  :scroll="{ y: 300 }"
             :dataSource="tableData" :columns="tableColumn"/>
  </div>

</template>

<script setup>
import {ref} from 'vue';
import http from "@/utils/axios/index.js";

let tableData = ref([])
let tableColumn = initColumns()
getAjaxData()

function getAjaxData() {
  http.get("/goods/fruit/list")
      .then(resp => {
        if (resp && resp.data.code === 200) {
          tableData.value = resp.data.data
        }
      })
      .catch(err => {
      })
}
function initColumns(){
  let columns = []
  columns.push(
      {
        title: '编码',
        dataIndex: 'frCode',
        key: 'frCode',
        minWidth: 150
      },
      {
        title: '名称',
        dataIndex: 'frName',
        key: 'frName',
        minWidth: 200
      },
      {
        title: '价格',
        dataIndex: 'frPrice',
        key: 'frPrice',
        minWidth: 120
      },
  )
  return columns
}
</script>

<style scoped>

</style>
相关推荐
breeze_whisper21 小时前
浏览器兼容性有何解?plugin-legacy
vite·前端工程化
前端开发爱好者2 天前
Vite 7.1.1 疑似遭受大规模 "攻击"!
前端·vue.js·vite
小徐_23332 天前
uni-app 还在手写请求?alova 帮你全搞定!
前端·uni-app·axios
har01d2 天前
【CSS3】录音中。。。
前端·css·vue.js·vue·vue3·css3
知识分享小能手2 天前
Vue3 学习教程,从入门到精通,Vue 3 + Tailwind CSS 全面知识点与案例详解(31)
前端·javascript·css·vue.js·学习·typescript·vue3
jason_yang3 天前
vite中的import.meta属性
vite·ecmascript 6
乐潇游4 天前
从零搭建 Vite + React + Tailwind CSS 企业级应用
前端·react.js·vite
小徐_23334 天前
uni-app 网络请求终极选型:uni.request、axios、uni-network、alova 谁才是你的真命请求库?
前端·uni-app·axios
晓得迷路了4 天前
栗子前端技术周刊第 93 期 - ECharts 6.0、Vite 领域新动态汇总、Cursor 1.4...
前端·javascript·vite
已读不回1436 天前
从侵入式改造到声明式魔法注释的演进之路
javascript·vite