关于vue/cli3打包空白页问题解决

前提

在vue-cli2中也出现过打包后本地打开index.html空白页问题,解决办法:修改config文件夹中ndex.js文件中assetsPublicPath属性为assetsPublicPath: ‘./’,路由用hash模式
在这里插入图片描述
在这里插入图片描述

环境

  • vue-cli3
  • package.json文件如下:
{
  "name": "my-temp",
  "version": "0.1.0",
  "private": true,
  "scripts": {
    "serve": "vue-cli-service serve",
    "build": "vue-cli-service build",
    "lint": "vue-cli-service lint"
  },
  "dependencies": {
    "core-js": "^2.6.5",
    "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",
    "babel-eslint": "^10.0.1",
    "eslint": "^5.16.0",
    "eslint-plugin-vue": "^5.0.0",
    "vue-template-compiler": "^2.6.10"
  }
}

vue-cli3解决办法

  • 新建vue.config.js文件,添加配置项:publicPath: ‘./’
module.exports = {
    publicPath: './',
}

vue.config.js目录位置
vue.config.js目录位置

  • 路由用hash模式
    在这里插入图片描述

效果

在这里插入图片描述
官网对publicPath属性说明:

部署应用包时的基本 URL。用法和 webpack 本身的 output.publicPath 一致,但是 Vue CLI 在一些其他地方也需要用到这个值,所以请始终使用 publicPath 而不要直接修改 webpack 的 output.publicPath。
默认情况下,Vue CLI 会假设你的应用是被部署在一个域名的根路径上,例如 https://www.my-app.com/。如果应用被部署在一个子路径上,你就需要用这个选项指定这个子路径。例如,如果你的应用被部署在 https://www.my-app.com/my-app/,则设置 publicPath 为 /my-app/。
这个值也可以被设置为空字符串 (’’) 或是相对路径 (’./’),这样所有的资源都会被链接为相对路径,这样打出来的包可以被部署在任意路径,也可以用在类似 Cordova hybrid 应用的文件系统中。

官网链接地址:publicPath描述

Vue.js 是一种流行的 JavaScript 框架,通过它能开发快速、优化和健壮的单页应用程序。Vue.js 3 是新版的 Vue.js,目前已经发布了 beta 版本,并且有很多新特性让它比以前的版本更强大和更易于使用。 在 Vue.js 3 中,官方提供了一个新的路由器 API,叫做 history 路由,它使用 HTML5 的 history API 来导航单页应用程序。这个 API 使得开发者可以使用 Vue.js 3 与单页应用程序更加深入地交互。 然而,有时候在打包 Vue.js 3 应用程序时可能会遇到 history 路由打包空白问题。这个问题的出现可能是因为在打包应用程序时,Webpack 没有正确地配置输出路径。具体来说就是,Webpack 没有设置 publicPath 选项。 PublicPath 选项是一个配置选项,它定义了应用程序文件的 URL 前缀,当应用程序被部署到生产环境并使用不同的 URL 时必须使用它。如果没有设置 publicPath,应用程序的资源文件(如 JavaScript 和 CSS 文件)将被查找在相对路径的根目录下,这可能导致路由页面空白。 为了解决这个问题,需要在 webpack 配置文件中设置 publicPath 选项。你可以从 Vue CLI 的内置配置文件中获取到这个选项,也可以在项目中手动设置它。设置 publicPath 选项后,Webpack 将根据 publicPath 的设置来查找文件路径,从而正确地加载资源文件,保证页面可以正确地呈现。 总之,如果在打包 Vue.js 3 应用程序时遇到了 history 路由打包空白问题,需要检查 publicPath 选项是否正确地设置了。这样可以从根本上解决问题并保证应用程序正常运行。
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值