亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

解決vue3項(xiàng)目打包發(fā)布到服務(wù)器后訪問頁(yè)面顯示空白問題

 更新時(shí)間:2023年03月19日 15:49:22   作者:月影星云  
這篇文章主要介紹了解決vue3項(xiàng)目打包發(fā)布到服務(wù)器后訪問頁(yè)面顯示空白問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

vue3項(xiàng)目打包發(fā)布到服務(wù)器后訪問頁(yè)面顯示空白

1、處理vue.config.js文件中的publicPath

處理如下:

const { defineConfig } = require('@vue/cli-service')
module.exports = defineConfig({
? ? publicPath: process.env.NODE_ENV === 'production' ? './' : '/',
?? ?outputDir: 'dist',
?? ?indexPath: 'index.html',
?? ?lintOnSave: false,
? ? transpileDependencies: true,
})

2、處理router文件夾中的index.js文件

處理如下:采用修改后的部分

import { createRouter, createWebHistory, createWebHashHistory ?} from 'vue-router';
import routes from "./routes";

const router = createRouter({
?? ?//history: createWebHistory(process.env.BASE_URL),//默認(rèn)時(shí)
?? ?history: createWebHashHistory(process.env.BASE_URL),//修改后
?? ?routes
})
export default router;

解決以上這兩步,就解決vue3項(xiàng)目打包發(fā)布到服務(wù)器后訪問頁(yè)面顯示空白問題

在打包項(xiàng)目時(shí)顯示空白頁(yè)問題和一些解決思路

在項(xiàng)目開發(fā)完畢后我們就會(huì)進(jìn)行打包

npm run build

打包生成的文件會(huì)在dist文件夾中

但有時(shí)候打開index.html 會(huì)出現(xiàn)空白頁(yè)面

接下來我們從幾個(gè)方面來進(jìn)行分析:

一、打包時(shí)整體資源路徑

根據(jù)實(shí)際情況要判斷    是/   還是 ./ 

在vue-ui 里配置:

在vue.config.js里配置:

module.exports = {
//基本路徑 文件打包后放的位置
publicPath:‘./',
 
//默認(rèn)輸出文件夾為dist,填入的名字為打包后的文件名
outputDir:‘name',
 
// 放置生成的靜態(tài)資源 (js、css、img、fonts) 的 (相對(duì)于 outputDir 的) 目錄。資源放的目錄
assetsDir: “./static”,
 
// 指定生成的 index.html 的輸出路徑 (相對(duì)于 outputDir)。也可以是一個(gè)絕對(duì)路徑 index的路勁和名字
indexPath: ‘./index.html',
 
//打包后是否生成map文件,map文件能看到錯(cuò)誤代碼位置,設(shè)置為false不生成map文件,打包體積縮小
productionSourceMap: false,
}

二、路由模式

是哈希 還是 歷史模式 

推薦 哈希模式 兼容性更高 #以后路徑不會(huì)發(fā)送給服務(wù)器 避免一些錯(cuò)誤

const router = new VueRouter({
  routes,
  mode:'hash',
})

三、開發(fā)和生產(chǎn)環(huán)境切換的原因

因?yàn)槲覀冮_發(fā)環(huán)境時(shí)

npm run serve 模擬的是本地服務(wù)器

打包成dist文件夾 導(dǎo)致端口等一些變化 當(dāng)中的內(nèi)容請(qǐng)求不過來 所以導(dǎo)致空白頁(yè)

我們可以簡(jiǎn)單部署本地服務(wù)器讓 dist 跑起來

創(chuàng)建文件夾

  • 在文件夾終端 初始化 npm npm init -y
  • 安裝 express  npm i express -S
  • 把dist 復(fù)制到新文件夾中
  • 創(chuàng)建 app.js 寫代碼

開啟gzip 減小文件體積 使傳輸速度更快

  • 安裝對(duì)應(yīng)包  npm install compression -p
  • 導(dǎo)入包 const compression = require('compression')
  • 啟用中間件 app.use(compression())

使用PM2 管理應(yīng)用

  • 安裝 npm i pm2 -g
  • 啟動(dòng)項(xiàng)目:pm2 start .\app.js --自定義名稱
  • 查看運(yùn)行項(xiàng)目 pm2 ls
  • 重啟項(xiàng)目 pm2 restart 自定義名稱(ID)
  • 停止項(xiàng)目 pm2 stop 自定義名稱(ID)
  • 刪除項(xiàng)目 pm2 delete 自定義名稱(ID)

app.js:

const express = require('express')
const app = express()
 
const compression = require('compression')
 
app.use(compression()) // 一定要把這一行寫在 靜態(tài)資源托管之前
app.use(express.static('./dist'))
 
app.listen(80,()=> {
  console.log('server running at http://127.0.0.1')
})

在這里能跑起來 dist 給后端大哥也不成問題了

四、執(zhí)行構(gòu)建之前可以進(jìn)行一些優(yōu)化

在 vue.confjg.js 中分別設(shè)置 本地服務(wù) 和 構(gòu)建 的入口文件

module.exports = {
  chainWebpack:config=>{
    //發(fā)布模式
    config.when(process.env.NODE_ENV === 'production',config=>{
      //entry找到默認(rèn)的打包入口,調(diào)用clear則是刪除默認(rèn)的打包入口
      //add添加新的打包入口
      config.entry('app').clear().add('./src/main-prod.js')
 
      //使用externals設(shè)置排除項(xiàng)
      config.set('externals',{
        vue:'Vue',
        axios:'axios',
        lodash:'_',
        echarts:'echarts',
        nprogress:'NProgress',
      })
 
// 在項(xiàng)目的根目錄創(chuàng)建一個(gè)vue.config.vue文件,添加上 chainWebpack,修改args里的參數(shù)配置,重新返回就可以  這里是 判斷是開發(fā)版本 還是 發(fā)布版本
      config.plugin('html').tap(args => {
        args[0].isProd = true
        return args
      })
 
    })
    //開發(fā)模式
    config.when(process.env.NODE_ENV === 'development',config=>{
      config.entry('app').clear().add('./src/main-dev.js')
 
      config.plugin('html').tap(args => {
        args[0].isProd = false
        return args
      })
    })
 
  }
}
  • main-dev.js 開發(fā)版本總?cè)肟?/li>
  • main-prod.js 發(fā)布版本總?cè)肟?在這里根據(jù)開發(fā)版本改進(jìn) 刪除不需要的依賴項(xiàng) 改用cdn引入、配置路由懶加載的插件......

總結(jié)

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • 教你在vue?中使用?svg?symbols

    教你在vue?中使用?svg?symbols

    這篇文章主要介紹了如何在?vue?中使用?svg?symbols,本文通過示例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-08-08
  • 解決vue3項(xiàng)目打包發(fā)布到服務(wù)器后訪問頁(yè)面顯示空白問題

    解決vue3項(xiàng)目打包發(fā)布到服務(wù)器后訪問頁(yè)面顯示空白問題

    這篇文章主要介紹了解決vue3項(xiàng)目打包發(fā)布到服務(wù)器后訪問頁(yè)面顯示空白問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-03-03
  • Vue+elementUI實(shí)現(xiàn)多圖片上傳與回顯功能(含回顯后繼續(xù)上傳或刪除)

    Vue+elementUI實(shí)現(xiàn)多圖片上傳與回顯功能(含回顯后繼續(xù)上傳或刪除)

    這篇文章主要介紹了Vue+elementUI實(shí)現(xiàn)多圖片上傳與回顯功能(含回顯后繼續(xù)上傳或刪除),本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-03-03
  • Vue+tracking.js 實(shí)現(xiàn)前端人臉檢測(cè)功能

    Vue+tracking.js 實(shí)現(xiàn)前端人臉檢測(cè)功能

    這篇文章主要介紹了Vue+tracking.js 實(shí)現(xiàn)前端人臉檢測(cè)功能,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-04-04
  • 深度剖析?Vue3?在瀏覽器的運(yùn)行原理

    深度剖析?Vue3?在瀏覽器的運(yùn)行原理

    這篇文章主要介紹了深度剖析Vue3在瀏覽器的運(yùn)行原理,文章通過圍繞主題展開相關(guān)詳細(xì)介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下
    2022-09-09
  • 詳解mpvue小程序中怎么引入iconfont字體圖標(biāo)

    詳解mpvue小程序中怎么引入iconfont字體圖標(biāo)

    這篇文章主要介紹了詳解mpvue小程序中怎么引入iconfont字體圖標(biāo),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-10-10
  • vue組件開發(fā)之slider組件使用詳解

    vue組件開發(fā)之slider組件使用詳解

    這篇文章主要為大家詳細(xì)介紹了vue組件開發(fā)之slider組件的使用方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-08-08
  • Vue如何實(shí)現(xiàn)el-table多選樣式變?yōu)閱芜x效果

    Vue如何實(shí)現(xiàn)el-table多選樣式變?yōu)閱芜x效果

    這篇文章主要介紹了Vue如何實(shí)現(xiàn)el-table多選樣式變?yōu)閱芜x效果,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-05-05
  • Vue項(xiàng)目中如何配置src文件下的@別名

    Vue項(xiàng)目中如何配置src文件下的@別名

    這篇文章主要介紹了Vue項(xiàng)目中如何配置src文件下的@別名問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • vue3+ts使用APlayer的示例代碼

    vue3+ts使用APlayer的示例代碼

    這篇文章主要介紹了vue3+ts使用APlayer的示例代碼,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-08-08

最新評(píng)論