vue中loading chunk-xxx.css failed和net::ERR_ABORTED 404 解决方法

前言

本文只是记录了自己经历项目出现的Loading chunk-xxx.css failed问题出现的原因和解决方法,该问题出现的原因可能和项目所使用的框架有关,并且出现的条件比较苛刻,可能并不适用于所有的情况,具体可看文章的第3部分3.总结问题出现原因,这里仅展示了一种解决思路。
项目的框架是:vue 2.6.10 + element-ui 2.11.1

  "dependencies": {
    "core-js": "^2.6.5",
    "mjs-brood-request": "^1.0.1",
    "mjs-brood-starport": "^1.0.0",
    "vue": "^2.6.10",
    "vue-router": "^3.0.3",
    "vuex": "^3.0.1"
  },
  "devDependencies": {
    "@vue/cli-plugin-babel": "^3.11.0",
    "@vue/cli-plugin-eslint": "^3.11.0",
    "@vue/cli-service": "^3.11.0",
    "axios": "^0.19.0",
    "babel-eslint": "^10.0.1",
    "body-parser": "latest",
    "element-ui": "^2.11.1",
    "eslint": "^5.16.0",
    "eslint-plugin-vue": "^5.0.0",
    "font-awesome": "^4.7.0",
    "lodash": "^4.17.15",
    "qs": "latest",
    "sass": "^1.18.0",
    "sass-loader": "^7.1.0",
    "vue-template-compiler": "^2.6.10"
  }

1. 问题现象

在本地环境运行中,完全没有问题,但是vue项目打包发布之后,在测试服务器显示类似于Loading CSS chunk-5f3f0dd6.aa1bfa6f.css failed这样的错误。
在这里插入图片描述
就是显示xx.css文件找不到,前端页面报错,页面的数据信息也渲染不出来。
但是,奇怪的是根据报错的路径,去查看chunk-xxx.css文件,发现这个文件是存在的,这个就很奇怪,明明存在为什么会报错呢。
在这里插入图片描述

2. 解决方法

在网上搜索解决方案,大家都是提到了懒加载云云,使用router.onError来处理,但是我试了还是不行。

// loading chunk 出错处理
router.onError((error) => {
  const pattern = /Loading chunk (\d)+ failed/g
  const isChunkLoadFailed = error.message.match(pattern)
  const targetPath = router.history.pending.fullPath
  if (isChunkLoadFailed) {
    router.replace(targetPath)
  }
})

后来仔细观察这些css文件,发现提示404 not found 的文件大小为0,而其它正常的css文件都有正常的大小,于是联想到在这个页面中,我把无用的css样式的代码全都注释了,这个页面比较简单,只有这一个样式的代码,等于我注释了该页面的所有css样式代码。如下图所示:
在这里插入图片描述
会不会是这样注释后的代码打包时,造成了css文件错误呢? 我把这些注释后无用的代码全部删除了,如图所示:
在这里插入图片描述
再次打包此项目,问题得以解决,页面也可以正常显示了。

3. 总结问题出现原因

总结问题出现的原因,可能的原因如下:

1.该vue页面中,所有的css样式代码全部被注释了
2.这些注释的代码没有被删除,只留下了类似于这样的代码块

<style scoped>
/* 
  ...
} */
</style>

所以打包时,生成的chunk-xxx.css文件是0字节,进而因为某种原因,出现了Loading chunk-xxx.css failed的现象。
在这里插入图片描述

Vue是一种非常流行的前端框架,它伴随着互联网的发展和技术进步而出现和发展。虽然Vue是一个非常出色的前端框架,但是在使用的过程难免会遇到各种问题,如Vue报错net::err_connection_aborted。 net::err_connection_aborted是一种在使用Vue开发项目时可能会遇到的错误,在这种情况下,我们打开浏览器时会看到一个类似于“Page Not Found”的提示。这种情况的出现通常是因为前端代码无法正确地与服务器建立连接而导致的。 要解决这个问题,我们需要检查一些常见的问题: 首先,我们需要检查网络连接是否正常。如果我们的网络连接出现问题,我们将无法与服务器建立连接,这就会导致net::err_connection_aborted的错误。 其次,我们需要检查服务器是否处于正常运行状态。如果服务器出现问题,它将无法响应我们的请求,从而导致net::err_connection_aborted的错误。 此外,我们需要检查Vue应用程序的代码是否存在错误或者页面的路径是否正确。如果我们的代码存在错误或者路径错误,我们将无法正确地获取服务器端的数据,从而导致net::err_connection_aborted的错误。 总的来说,解决Vue报错net::err_connection_aborted的问题需要我们仔细检查网络连接、服务器状态以及代码路径等可能影响的问题,并逐一解决它们。只有这样我们才能确保我们的Vue应用程序能够正确地运行并提供稳定的服务。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值