vue 项目配置反向代理导致项目白屏

问题:vue 项目配置反向代理导致项目白屏

一、现象描述

添加反向代理代码后,前端运行白屏

复制代码
// 设置baseURL,8888是后端端口号,前端请求默认发送到baseURL的地址
var axios = require('axios')
axios.defaults.baseURL = 'http://localhost:8888/api'
// 全局注册,之后可在其他组件中通过 this.$axios 发送数据
Vue.prototype.$axios = axios

二、问题分析

通过F12查看控制台

复制代码
Uncaught TypeError: Cannot set properties of undefined (setting 'baseURL')

Uncaught TypeError: Cannot read properties of undefined 是一个 JavaScript 运行时错误,它表示试图访问一个未定义(undefined)对象的属性。访问对象是一个不存在的变量或者对象的属性。

复制代码
axios.defaults.baseURL = 'http://localhost:8888/api'

出问题的是这句话,注释掉就能显示。

代码解释(熟悉的同学可略过此节)

axios.defaults.baseURL = 'http://localhost:8888/api' 是一行JavaScript代码,通常用于配置Axios库的默认基础URL。

  1. axios: Axios 是一个基于 Promise 的 HTTP 客户端,用于浏览器和 Node.js。它允许你发出GET、POST等HTTP请求。

  2. defaults: 这是Axios对象的一个属性,用于设置Axios的默认配置。

  3. baseURL : 这是Axios默认配置中的一个属性,用于设置请求的基础URL。这意味着当你使用axios发起请求时,如果请求的URL以baseURL开始,那么你不需要重复写baseURL

  4. 'http://localhost:8888/api': 这是你设置的基础URL。这意味着当你使用axios发起请求时,除非你明确指定了不同的URL,否则都会基于这个URL。例如,如果你发起一个GET请求,而请求的URL是'/users',那么实际发送的请求URL会是'http://localhost:8888/api/users'

设置基础URL的主要目的是为了简化代码和提高可读性。例如,如果你有一个API端点是'/users',那么你可以这样发起请求:

复制代码
axios.get('/users')  
  .then(response => {  
    console.log(response.data);  
  })  
  .catch(error => {  
    console.error(error);  
  });

而不是这样:

复制代码
axios.get('http://localhost:8888/api/users')  
  .then(response => {  
    console.log(response.data);  
  })  
  .catch(error => {  
    console.error(error);  
  });

通过设置基础URL,你可以避免在每个请求中重复写相同的URL前缀。

三、解决方案

1.检查变量是否定义

2.使用默认参数

3.使用链式表达

博主的项目实际解决方法是通过

复制代码
import axios from 'axios'

代替

复制代码
// var axios = require('axios')

根本原因分析,先挖个坑。

相关推荐
寰宇软件9 小时前
PHP商会招商项目系统小程序
小程序·uni-app·vue·php
SuperHeroWu79 小时前
【HarmonyOS NEXT】设备显示白屏 syswarning happended in XXX
harmonyos·鸿蒙·error·白屏·syswarning·happended
寰宇软件18 小时前
PHP填表统计预约打卡表单系统小程序
小程序·uni-app·vue·php
小Mie不吃饭1 天前
2025新时代 | 分析并解决企业跨域问题
前端·后端·springboot·api·web·跨域
飞翔的佩奇2 天前
Java项目: 基于SpringBoot+mybatis+maven+mysql实现的健身房管理系统(含源码+数据库+毕业论文)
java·数据库·spring boot·mysql·vue·毕业设计·健身房
孔明click332 天前
Sa-Token v1.40.0 发布 🚀,来看看有没有令你心动的功能!
java·sa-token·springboot·权限·权限认证
tekin3 天前
Vue.js组件开发
前端·javascript·vue.js·vue·vue组件·vue.js组件开发
大模型铲屎官3 天前
前端框架中 HTML 的应用技巧:React、Vue、Angular 深度解析
react.js·前端框架·vue·html·编程·html5·angular
码农研究僧3 天前
Vue 图片引用方式详解:静态资源与动态路径访问
vue·路由·image·public
16年上任的CTO3 天前
vue生命周期及其作用
前端·javascript·vue.js·vue