Vue 3 + Vite 項目配置訪問地址到服務器某個文件夾的解決方案

前言

在開發 Vue 3 + Vite 項目時,我們經常需要將項目部署到服務器的某個特定文件夾下。例如,將項目部署到?/my-folder/?目錄下,而不是服務器的根目錄。這時,我們需要對 Vite 和 Vue Router 進行一些配置,以確保項目能夠正確訪問資源和處理路由。

本文將詳細介紹如何配置 Vite 的?base?選項以及 Vue Router 的路由模式,解決部署到服務器子文件夾時可能遇到的問題。

問題描述

在 Vue 3 + Vite 項目中,默認情況下,Vite 會將資源路徑指向根目錄(/)。如果我們將項目部署到服務器的子文件夾(例如?/my-folder/),可能會出現以下問題:

  1. 資源加載失敗:JS、CSS 等靜態資源路徑不正確,導致頁面無法正常加載。

  2. 路由失效:如果使用了 Vue Router 的?history?模式,路由可能無法正確匹配。

為了解決這些問題,我們需要對 Vite 和 Vue Router 進行配置。

解決方案

1. 配置 Vite 的?base?選項

Vite 提供了一個?base?配置項,用于指定項目的公共基礎路徑。我們可以通過修改?vite.config.js?文件來設置?base

示例:將?base?配置為?/my-folder/
import { defineConfig } from 'vite';
import vue from '@vitejs/plugin-vue';export default defineConfig({plugins: [vue()],base: '/my-folder/' // 設置基礎路徑
});
示例:將?base?配置為?./

如果你希望使用相對路徑(例如直接打開?index.html?文件),可以將?base?配置為?./

import { defineConfig } from 'vite';
import vue from '@vitejs/plugin-vue';export default defineConfig({plugins: [vue()],base: './' // 使用相對路徑
});

2. 配置 Vue Router

如果你在項目中使用了 Vue Router,還需要根據?base?的配置調整路由的設置。

情況 1:使用?hash?模式

hash?模式(URL 中有?#)不依賴于服務器的路徑配置,因此即使?base?是?./?或?/my-folder/,路由也能正常工作。

import { createRouter, createWebHashHistory } from 'vue-router';const router = createRouter({history: createWebHashHistory(), // 使用 hash 模式routes: [// 路由配置]
});export default router;
情況 2:使用?history?模式

history?模式(URL 中沒有?#)依賴于服務器的路徑配置。如果?base?是?/my-folder/,則需要將?createWebHistory?的?base?參數設置為?/my-folder/

import { createRouter, createWebHistory } from 'vue-router';const router = createRouter({history: createWebHistory('/my-folder/'), // 與 Vite 的 base 保持一致routes: [// 路由配置]
});export default router;

如果?base?是?./,則需要將?createWebHistory?的?base?參數設置為?./

import { createRouter, createWebHistory } from 'vue-router';const router = createRouter({history: createWebHistory('./'), // 與 Vite 的 base 保持一致routes: [// 路由配置]
});export default router;

3. 部署到服務器

完成配置后,運行以下命令構建項目:

npm run build

構建后的文件會生成在?dist?目錄下。將?dist?目錄中的內容上傳到服務器的目標文件夾(例如?/my-folder/)。

服務器配置示例(Nginx)

如果你使用 Nginx 作為服務器,可以按照以下配置:

server {listen 80;server_name your-domain.com;location /my-folder/ {alias /path/to/your/my-folder/;try_files $uri $uri/ /my-folder/index.html;}
}

4. 注意事項

  • 如果?base?配置為?./,并且使用?history?模式,直接通過文件協議(file://)打開?index.html?可能會導致路由失效。此時建議使用?hash?模式。

  • 確保服務器的配置正確,尤其是使用?history?模式時,需要配置服務器支持 fallback 到?index.html

總結

通過以上配置,我們可以輕松地將 Vue 3 + Vite 項目部署到服務器的某個文件夾下。關鍵點如下:

  1. Vite 配置:通過?base?選項設置項目的基礎路徑。

  2. Vue Router 配置:根據?base?的配置調整路由模式(hash?或?history)。

  3. 服務器配置:確保服務器正確指向目標文件夾,并支持 fallback 到?index.html

希望本文能幫助你解決 Vue 3 + Vite 項目部署中的路徑問題。如果有任何疑問,歡迎在評論區留言討論!

?

?

?

?

?

?

?

?

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/70842.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/70842.shtml
英文地址,請注明出處:http://en.pswp.cn/web/70842.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

【Rust中級教程】2.10. API設計原則之受約束性(constrained) Pt.1:對類型進行修改、`#[non_exhaustive]`注解

喜歡的話別忘了點贊、收藏加關注哦(加關注即可閱讀全文),對接下來的教程有興趣的可以關注專欄。謝謝喵!(・ω・) 2.10.1. 接口的更改要三思 如果你的接口要做出對用戶可見的更改,那么一定要三思…

Imagination GPU 3D Graphics Wrokload

本次分享Imagination GPU 的3D 圖像處理負載流程。 總的分為兩個階段 第一階段:Geometry Processing Phase(幾何處理階段)是渲染管線中的一個關鍵環節,主要負責對三維幾何數據進行處理和變換,以便后續在屏幕上進行顯…

自動化設備對接MES系統找DeepSeek問方案

項目需要現場的PLC設備HTTP協議JSON格式的方式對接MES系統平臺,于是試了一下: 找到的相關資源鏈接在這里。

VoIP之音頻3A技術

音頻3A技術是改善語音通話質量的三種關鍵技術的簡稱,包括聲學回聲消除(Acoustic Echo Cancellation, AEC)、自動增益控制(Automatic Gain Control, AGC)、自噪聲抑制(Automatic Noise Suppression, ANS&…

量子計算的數學基礎:復數、矩陣和線性代數

量子計算是基于量子力學原理的一種新型計算模式,它與經典計算機在信息處理的方式上有著根本性的區別。在量子計算中,信息的最小單位是量子比特(qubit),而不是傳統計算中的比特。量子比特的狀態是通過量子力學中的數學工具來描述的,因此,理解量子計算的數學基礎對于深入學…

京準電鐘:NTP精密時鐘服務器在自動化系統中的作用

京準電鐘:NTP精密時鐘服務器在自動化系統中的作用 京準電鐘:NTP精密時鐘服務器在自動化系統中的作用 NTP精密時鐘服務器在自動化系統中的作用非常重要,特別是在需要高精度時間同步的場景中。NTP能夠提供毫秒級的時間同步精度,這…

Python實現GO鵝優化算法優化Catboost回歸模型項目實戰

說明:這是一個機器學習實戰項目(附帶數據代碼文檔視頻講解),如需數據代碼文檔視頻講解可以直接到文章最后關注獲取。 1.項目背景 在當今的數據驅動時代,機器學習模型在各種應用中扮演著至關重要的角色。特別是在預測分…

如何在docker上部署前端nginx服務(VUE)

目錄結構 clean.sh docker stop rszWeb; docker rm rszWeb; start.sh docker run -d \ --name rszWeb \ -p 7084:80 \ -m 500m \ --privileged=true \ --restart=always \ -v /home/rsz/ui/conf/nginx.conf:/etc/nginx/nginx.conf \ -v /home/rsz/ui/logs:/meta/logs \ -v /…

可獄可囚的爬蟲系列課程 15:防盜鏈反爬蟲的處理

一、防盜鏈了解 防盜鏈是一種技術手段,主要用于防止其他網站通過直接鏈接的方式使用本網站的資源(如圖片、文件等),從而節省帶寬和服務器資源。當其他網站嘗試直接鏈接到受保護的資源時,服務器會根據設置的規則判斷請求…

2020年藍橋杯Java B組第二場題目+部分個人解析

#A&#xff1a;門牌制作 624 解一&#xff1a; public static void main(String[] args) {int count0;for(int i1;i<2020;i) {int ni;while(n>0) {if(n%102) {count;}n/10;}}System.out.println(count);} 解二&#xff1a; public static void main(String[] args) {…

Hadoop架構詳解

Hadoop 是一個開源的分布式計算系統&#xff0c;用于存儲和處理大規模數據集。Hadoop 主要由HDFS&#xff08;Hadoop Distributed File System&#xff09;、MapReduce、Yarn&#xff08;Jobtracker&#xff0c;TaskTracker&#xff09;三大核心組件組成。其中HDFS是分布式文件…

DeepSeek在初創企業、教育和數字營銷領域應用思考

如今&#xff0c;像 DeepSeek 這樣的人工智能工具正在改變企業的運營方式&#xff0c;優化流程并顯著提高生產力。通過重復任務的自動化、大量數據的分析以及內容創建效率的提高&#xff0c;組織正在尋找新的競爭和卓越方式。本文介紹了 DeepSeek 如何用于提高三個關鍵領域的生…

day7作業

編寫一個如下場景&#xff1a; 有一個英雄Hero類&#xff0c;私有成員&#xff0c;攻擊&#xff08;Atx&#xff09;&#xff0c;防御&#xff08;Defense&#xff09;&#xff0c;速度&#xff08;Speed)&#xff0c;生命值&#xff08;Blood)&#xff0c;以及所有的set get 方…

阿里云ack的創建與實戰應用案例

阿里云ack的創建與應用案例 創建前開通ack相關服務&#xff1a;開始創建簡單的魔方游戲&#xff0c;熟悉sv與clb自動注冊創建部署一個nginx 服務示例&#xff1a;走不同域名訪問不同svc資源&#xff1a;為什么需要 Ingress &#xff1f;創建第一個域名的 Deployment和Service。…

青少年編程都有哪些比賽可以參加

Python小學生可參加的賽事&#xff1a; 電子學會青少年編程考級、中國計算機學會編程能力等級認證、藍橋杯、 信奧賽CSP-J/S初賽/NOIP(推薦C)、編程設計、信息素養、科技創新賽&#xff1b; 升學助力(科技特長生、大學)、企業、出國留學&#xff1b; python比賽&am…

MinIO在 Docker中修改登錄賬號和密碼

MinIO在 Docker中修改登錄賬號和密碼 隨著云計算和大數據技術的快速發展&#xff0c;對象存儲服務逐漸成為企業數據管理的重要組成部分。MinIO 作為一種高性能、分布式的對象存儲系統&#xff0c;因其簡單易用、高效可靠的特點而備受開發者青睞。然而&#xff0c;在實際應用中…

pycharm編寫ai大模型api調用程序及常見錯誤

這里寫目錄標題 一級目錄1. 訪問Django項目&#xff0c;python web url時&#xff0c;報錯2. 傳參報名&#xff0c;python web url時&#xff0c;報錯正確訪問結果&#xff1a; 二、購買價格 和 見錯誤碼 一級目錄 1. 訪問Django項目&#xff0c;python web url時&#xff0c;…

RISCV指令集解析

參考視頻&#xff1a;《RISC-V入門&進階教程》1-4-RV32I基本指令集&#xff08;1&#xff09;_嗶哩嗶哩_bilibili privilege是特權指令集&#xff0c;有點系統調用的感覺&#xff0c;要走內核態。unprivilege指令集有點像普通的函數調用。

Java中的TreeMap

TreeMap繼承自AbstractMap&#xff0c;并實現了NavigableMap接口(NavigableMap繼承自SortedMap接口)。底層的數據結構是紅黑樹&#xff0c;按照鍵的自然排序或者自定義實現的規則排序&#xff0c;實現元素的有序性。 特點 元素是有序的&#xff1a;按照key的自然排序或者是自…

vue3表單驗證的時候訪問接口如果有值就通過否則不通過.主動去觸發校驗

頁面有個身份證號碼的校驗。校驗完身份證格式是否符合之后還要去訪問接口查詢這個用戶是否存在。如果存在才通過驗證。否則就校驗不通過 <el-form ref"ruleFormRef" :model"form" label-width"140px" label-position"right" label…