欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

解決vite打包后白屏之router-view不生效問題

 更新時間:2024年07月05日 15:41:49   作者:xiaban_  
這篇文章主要介紹了解決vite打包后白屏之router-view不生效問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教

問題發(fā)現(xiàn)

項目打包后白屏,最開始是在打包后的dist文件中的index.html中路徑爆黃

控制臺報錯找不到資源

簡單搜索后發(fā)現(xiàn)在vite.config.ts中配置base: "./"即可解決報錯問題

import {defineConfig, loadEnv} from 'vite'  
import vue from '@vitejs/plugin-vue'  
// @ts-ignore  
import path from 'path'  
  
export default defineConfig(({ mode }) => {  
  
return {  
	base: "./",  
	plugins: [  
		vue()  
	],  
	resolve:{  
			alias:{  
			// @ts-ignore  
			'@': path.resolve(__dirname, './src')  
			}  
		}  
	}  
})

控制臺沒報錯了,但是依舊是白屏

開了個新項目,打包后能夠正常使用,初步判定是路由的問題,然后在本項目的App.vue中加了123,發(fā)現(xiàn)打包后可以顯示123,但是還是不顯示其他的頁面

<script setup lang="ts">  
  
</script>  
  
<template>  
	<div>  
		123  
	<router-view/>  
	</div>  
</template>  
  
<style scoped>  
  
</style>

解決方案

最后搜索了router-view為什么不顯示,找到一篇文章說vite打包的項目需要在服務(wù)端環(huán)境才可以正常訪問,不能直接客戶端瀏覽器訪問

如果是vscode,可以下載live server模擬服務(wù)端環(huán)境,如果是webstorm,則可以右上角直接點開就是模擬服務(wù)端環(huán)境

但是結(jié)果還是白屏,后續(xù)發(fā)現(xiàn)是只有路由模式是history的情況下,router-view才會失效,改為hash模式就可以生效了。

import {createRouter, createWebHashHistory} from "vue-router";  
import pay from "@/page/pay.vue";  
  
const routes = [  
	{ path: '/', component: pay,redirect:"/pay" },  
	{ path: '/pay', component: pay }  
]  
  
const router = createRouter({  
	history: createWebHashHistory(),  
	// @ts-ignore  
	routes, 
})  
  
export default router;

值得注意的是,如果不模擬服務(wù)端環(huán)境,直接在文件訪問,還是會報錯

補充

hash和history區(qū)別

簡單來說就是hash模式就是路徑中帶#的,history模式就是路徑中不帶#號

Hash模式

Hash 模式是通過監(jiān)聽 URL 中的 hash 值( # 及其后面的部分)來實現(xiàn)路由切換和組件渲染的。

優(yōu)點:

  • 兼容性好,支持所有瀏覽器,包括不支持 HTML5 History API 的老舊瀏覽器。
  • 服務(wù)端無需做特殊配置。

缺點:

  • URL 中有 # 號,不太美觀。
  • 部分老舊的瀏覽器可能會有效率問題。

Hash模式路由實現(xiàn)原理

在 hash 模式下,路由的實現(xiàn)主要依賴于 URL 的 hash 部分(即#后面的部分)。

History模式

History 模式利用 HTML5 History API 中的 pushState 和 replaceState 方法來實現(xiàn) URL 的導(dǎo)航,無需 # 號。

優(yōu)點:

  • 更加美觀,看起來像標準的網(wǎng)站鏈接。
  • 符合 HTML5 標準,支持瀏覽器的前進/后退按鈕。

缺點:

  • 部分老舊的瀏覽器不支持 HTML5 History API,需要使用墊片庫(Polyfill)來支持。
  • 需要在服務(wù)端做特殊配置,確保所有的 URL 都能找到應(yīng)用入口文件(例如 index.html),否則會出現(xiàn) 404 錯誤。

History模式路由實現(xiàn)原理

在history模式下,路由的實現(xiàn)主要依賴于HTML5的History API。

結(jié)語

如果是實在想要history模式的,可以在本地打包完需要測試的,改為hash模式后,用live server插件或者直接webstorm打開即可成功測試,準備部署后再修改為history模式

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

相關(guān)文章

  • vue.js滾動條插件vue-scroll的基本用法

    vue.js滾動條插件vue-scroll的基本用法

    在移動端或PC,頁面的部分內(nèi)容常常需要我們讓其在頁面滾動,這篇文章主要給大家介紹了關(guān)于vue.js滾動條插件vue-scroll的基本用法,文中通過代碼介紹的非常詳細,需要的朋友可以參考下
    2023-12-12
  • 解決element ui select下拉框不回顯數(shù)據(jù)問題的解決

    解決element ui select下拉框不回顯數(shù)據(jù)問題的解決

    這篇文章主要介紹了解決element ui select下拉框不回顯數(shù)據(jù)問題的解決,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-02-02
  • 100行代碼理解和分析vue2.0響應(yīng)式架構(gòu)

    100行代碼理解和分析vue2.0響應(yīng)式架構(gòu)

    通過100行代碼幫助大家理解和分析vue2.0響應(yīng)式架構(gòu)的相關(guān)資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-03-03
  • Vue.js遞歸組件實現(xiàn)組織架構(gòu)樹和選人功能案例分析

    Vue.js遞歸組件實現(xiàn)組織架構(gòu)樹和選人功能案例分析

    這篇文章主要介紹了Vue.js遞歸組件實現(xiàn)組織架構(gòu)樹和選人功能,本文通過案例代碼講解的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-07-07
  • vue2.0實現(xiàn)列表數(shù)據(jù)增加和刪除

    vue2.0實現(xiàn)列表數(shù)據(jù)增加和刪除

    這篇文章主要為大家詳細介紹了vue2.0實現(xiàn)列表數(shù)據(jù)增加和刪除,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-06-06
  • vue項目index.html中使用環(huán)境變量的代碼示例

    vue項目index.html中使用環(huán)境變量的代碼示例

    在Vue3中使用環(huán)境變量的方式與Vue2基本相同,下面這篇文章主要給大家介紹了關(guān)于vue項目index.html中使用環(huán)境變量的相關(guān)資料,文中通過代碼介紹的非常詳細,需要的朋友可以參考下
    2024-02-02
  • vue修改數(shù)據(jù)的時候,表單值回顯不正確問題及解決

    vue修改數(shù)據(jù)的時候,表單值回顯不正確問題及解決

    這篇文章主要介紹了vue修改數(shù)據(jù)的時候,表單值回顯不正確的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-11-11
  • Vue3項目實現(xiàn)前端導(dǎo)出Excel的示例代碼

    Vue3項目實現(xiàn)前端導(dǎo)出Excel的示例代碼

    這篇文章主要介紹了Vue3項目實現(xiàn)前端導(dǎo)出Excel的示例,在vue3的項目中導(dǎo)出Excel表格的功能,可以借助xlsx庫來實現(xiàn),下面是詳細的操作步驟,需要的朋友可以參考下
    2025-01-01
  • vue項目啟動命令個人學(xué)習(xí)記錄

    vue項目啟動命令個人學(xué)習(xí)記錄

    最近想要學(xué)習(xí)vue,正好看到資料,如何通過命令創(chuàng)建vue項目的方法,就留個筆記,下面這篇文章主要給大家介紹了關(guān)于vue項目啟動命令的相關(guān)資料,需要的朋友可以參考下
    2023-02-02
  • vue.js中$set與數(shù)組更新方法

    vue.js中$set與數(shù)組更新方法

    下面小編就為大家分享一篇vue.js中$set與數(shù)組更新方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-03-03

最新評論