TypeError: Cannot read property ‘upgrade‘ of undefined

在vue项目中,我配置了环境变量 .env.dev,同时配置了proxy
此时我的package.json中的serve 脚本命令为

"scripts": {
    "dev": "vue-cli-service serve --mode dev",
    "serve": "vue-cli-service serve",
    "build": "vue-cli-service build",
    "lint": "vue-cli-service lint"
  },

此时运行 npm run dev 正常

但运行 npm run serve 报错

10% building 2/2 modules 0 active ERROR  TypeError: Cannot read property 'upgrade' of undefined
TypeError: Cannot read property 'upgrade' of undefined
    at Server.<anonymous> (/Users/chengjiahui/tengquan/working-space/node_modules/webpack-dev-server/lib/Server.js:135:47)
    at Array.forEach (<anonymous>)
    at new Server (/Users/chengjiahui/tengquan/working-space/node_modules/webpack-dev-server/lib/Server.js:134:27)
    at serve (/Users/chengjiahui/tengquan/working-space/node_modules/@vue/cli-service/lib/commands/serve.js:172:20)
    at processTicksAndRejections (internal/process/task_queues.js:95:5)

在这里插入图片描述
最新的webpack-dev-serve 检测 未定义代理属性时发出警告

也就是说此时你的vue.config.js 文件中的 devServer.proxy.target 为undefined

解决方案 就是设置devServer.proxy.target,因为我使用的是环境变量 process.env.VUE_APP_BASE_API 的值
当我打印出来 确实是undefined,如果你写死成 ‘http://192.xxx.x.xx’ 也是不会出现这个问题的

应该是 执行 npm run serve 时 并不会默认读取 .env.dev 文件中 VUE_APP_BASE_API 的值,所以才显示为 undefined

当然正常配置了 .env.dev 文件,并执行 npm run dev 是不会出现问题的 我只是无聊 试了下 npm run serve 发现了这个问题

参考地址:https://github.com/webpack/webpack-dev-server/pull/3647
https://stackoverflow.com/questions/55348996/cannot-read-property-upgrade-of-undefined-when-starting-vue-application

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
TypeError: Cannot read property 'call' of undefined错误是指在调用一个未定义的对象的call方法时发生的错误。根据引用和引用[2]的内容,我们可以了解到这个错误通常发生在使用Vue.js路由时,可能是因为路由配置有误导致调用了未定义的函数或方法。 根据引用中提到的错误详情,TypeError通常是由于变量或参数不是预期类型引起的。在Vue.js中,路由配置常常使用到call方法来调用相应的函数,而当调用的对象是undefined时,就会触发该错误。 举个例子,假设在Vue.js路由配置中有如下代码: ```javascript router.beforeEach((to, from, next) => { // 在此处调用了一个不存在的函数 to.meta.beforeEnter.call(); next(); }); ``` 在这个例子中,to.meta.beforeEnter是一个函数对象,但如果这个函数对象未定义,就会产生TypeError: Cannot read property 'call' of undefined错误。 因此,解决这个错误的方法就是确保在路由配置中所调用的函数或方法都是已定义的。可以检查路由配置文件,确保所有使用到call方法的函数都是存在的。另外,也可以在调用函数之前先进行类型判断,避免调用未定义的函数。 总结起来,TypeError: Cannot read property 'call' of undefined错误通常发生在Vue.js路由配置中,是由于调用了未定义的函数或方法导致的。解决这个错误的方法是确保所有调用的函数都是已定义的,并进行必要的类型判断。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值