Vue:axios(POST请求)

发送 POST 请求

基本用法

javascript 复制代码
axios.post('/api/login', {
  username: 'lcyyyy',
  password: '123456'
})
.then(response => {
  console.log('请求成功:', response.data);
})
.catch(error => {
  console.error('请求失败:', error);
});

在 Vue 组件中使用

javascript 复制代码
export default {
  methods: {
    async submitForm() {
      try {
        const response = await axios.post('/api/submit', {
          name: this.name,
          email: this.email
        });
        console.log('提交成功:', response.data);
      } catch (error) {
        console.error('提交失败:', error.response?.data || error.message);
      }
    }
  }
}

处理请求参数

发送 JSON 数据(默认)

Axios 默认会将 JavaScript 对象序列化为 JSON,并自动设置请求头 Content-Type: application/json

发送表单数据(FormData)

如果需要提交表单格式数据(如文件上传),需使用 FormData

javascript 复制代码
const formData = new FormData();
formData.append('file', this.file); // 文件对象
formData.append('comment', '这是一个文件');

axios.post('/api/upload', formData, {
  headers: {
    'Content-Type': 'multipart/form-data' // Axios 会自动识别,可省略
  }
});

全局配置与拦截器

1全局默认配置

javascript 复制代码
// main.js 或单独配置文件
axios.defaults.baseURL = 'https://api.example.com';
axios.defaults.timeout = 5000; // 超时时间

请求拦截器

javascript 复制代码
axios.interceptors.request.use(config => {
  // 在发送请求前做些什么(如添加 token)
  config.headers.Authorization = `Bearer ${localStorage.getItem('token')}`;
  return config;
}, error => {
  return Promise.reject(error);
});

响应拦截器

javascript 复制代码
axios.interceptors.response.use(response => {
  // 对响应数据做统一处理
  return response.data; // 直接返回核心数据
}, error => {
  // 统一处理错误(如 401 跳转登录页)
  if (error.response.status === 401) {
    router.push('/login');
  }
  return Promise.reject(error);
});

相关推荐
砍材农夫几秒前
物联网 基于netty构建mqtt协议规范(主题通配符订阅)
java·前端·javascript·物联网·netty
广州华水科技8 分钟前
单北斗GNSS变形监测在基础设施安全中的应用与维护
前端
星栈16 分钟前
Rust 全栈项目里,我写了一个不再重复造轮子的泛型表格组件
前端·前端框架·开源
008爬虫实战录16 分钟前
【码上爬】 题九:webpack调试 堆栈分析
前端·webpack·node.js
爱滑雪的码农17 分钟前
React Native 完整开发全流程(从零到上线)
javascript·react native·react.js
HwJack2022 分钟前
HarmonyOS APP开发中ArkTS/JS 类型错误全景拆解
javascript·华为·harmonyos
子琦啊27 分钟前
构造函数、this指向和原型链机制
javascript·算法·贴图
Maimai108081 小时前
React 多步骤表单工程化落地:从 Zod Schema、React Hook Form 到 Zustand 持久化
前端·javascript·react.js·前端框架·状态模式
程序员码歌1 小时前
我是怎么部署开源 AI 编程助手 OpenCode,并在两个真实场景使用起来的
前端·人工智能·后端
Maimai108081 小时前
React Query + Zustand 正确结合方式:不要把接口数据复制进 Store
前端·javascript·react.js·前端框架·web3·状态模式