在asp.net core中使用vue3+vite(起)

来源:https://www.cnblogs.com/sigeer0-o/archive/2023/07/05/17526285.html
-Advertisement-
Play Games

## 前言 一開始是一個自用的應用,原本是用razor寫的。最近有了點新想法,加點新功能,但是我接觸的項目基本都是vue+api的前後端分離,用這razor寫的是真不習慣,最後決定還是用習慣的vue重寫。 之前嘗試過在.net core里使用vue2+webpack,畢竟實際上就是把.vue翻譯成了 ...


前言

一開始是一個自用的應用,原本是用razor寫的。最近有了點新想法,加點新功能,但是我接觸的項目基本都是vue+api的前後端分離,用這razor寫的是真不習慣,最後決定還是用習慣的vue重寫。

之前嘗試過在.net core里使用vue2+webpack,畢竟實際上就是把.vue翻譯成了.js來用,一個站點就能跑。但是vite不同於webpack的實在想不到怎麼弄到.net core里來。

另外我的前端不太行,對於vue基本上只會寫,不會搭。有些東西搞錯了敬請諒解。

環境

  • .net 6
  • pnpm 8.6.1
  • Visual Studio 2022 17.4

步驟

  1. 創建新項目,使用React的模板:
    image

  2. ClientApp文件夾下,就是React相關的內容,刪掉這個文件夾,然後在項目目錄下執行
    pnpm create vite 參考官網,Project Name就用ClientApp(可以改,但是沒必要,不然相應的.net core的部分也要改)然後後面選擇vue + typescript,直接一手鳩占鵲巢

  3. 打開項目文件.csproj,可以看到內容比普通的項目文件多很多。

    • <SpaRoot>[SpaRoot]</SpaRoot>,可以看到這裡就是ClientApp,如果上面創建project name不是ClientApp,這裡就要相應的修改了

    • <SpaProxyServerUrl>[SpaProxyServerUrl]</SpaProxyServerUrl>,這裡面的[SpaProxyServerUrl]就是vue運行用的url,把port改成vite預設的5173,即可。當vite.config.ts中配置了其他埠時,這裡要與之一致。

    • <SpaProxyLaunchCommand>[SpaProxyLaunchCommand]</SpaProxyLaunchCommand>,運行用的命令,這裡npm start是原react模板生成的package.json里的;現在換成pnpm run dev即可

    • <DistFiles Include="$(SpaRoot)build\**" /> 改成<DistFiles Include="$(SpaRoot)dist\**" />

3.5 若項目目錄下沒有wwwroot文件夾,手動創建。

4.調試運行:會先後啟動2個站點,一個是.net core,一個是vue。

5.發佈:正常生成發佈文件即可。

擴展

首先,調試運行會出現一個cmd,執行了pnpm run dev([SpaProxyLaunchCommand]),而Program.cs 里的

app.UseStaticFiles();
// ....
app.MapFallbackToFile("index.html");

這兩句代碼,前者對應的wwwroot文件夾是空的,後者需要的index.html更是不存在(wwwroot),那麼我對這兩句代碼進行一個釋的註,調試運行果然依然正常。

然後是這個 Microsoft.AspNetCore.SpaProxy 。從Program.cs沒有這個庫的一絲蹤跡,應該是寫在什麼了看不見的地方
在 ASP.NET Core 中使用承載啟動程式集

通過 IHostingStartup(承載啟動)實現,在啟動時從外部程式集嚮應用添加增強功能。 例如,外部庫可使用承載啟動實現為應用提供其他配置提供程式或服務。。

而通過調試運行的時候,可以看到是net core的站點會先顯示Launching the SPA proxy...,然後跳轉到vue站點。但是發佈運行,卻是直接顯示vue的首頁。我直接對發佈包里的Microsoft.AspNetCore.SpaProxy.dll進行一個除的刪,果然站點仍然能夠正常運行。

小結

在調試運行時,通過Microsoft.AspNetCore.SpaProxy支持站點運行。

生成發佈包後,通過app.UseStaticFiles();就可以支持站點運行(訪問/index.html即可)。

擴展里總結了一些內容,發現這裡基本上都有

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • Java的特點是百花齊放,不像c#或者go只有一家主導。oracle jdk收費了,沒關係,不是只有它可用。java還有很多免費的主流的jdk發行版本,記錄下來備忘。 OpenJDK - 官方網站 - 源代碼 - 文檔 - 下載地址 OpenJDK是其他所有jdk發行版的基礎,可以用於開發和測試,但 ...
  • 一、問題描述 近日在工作中遇見了一個bug,後端程式頻頻報錯 No bean named 'XXXXX' available 。對比同類程式文件,沒有發現有任何特殊之處。在網上搜索方法基本上就是掃描包配置、註解問題、路徑問題等,皆不能解決我的問題。 排查問題是發現出現問題的類命名不符合駝峰規範,按照 ...
  • ![](https://p3-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/f4928251cca8446891aafb4d014abf39~tplv-k3u1fbpfcp-zoom-1.image) 博主在瀏覽 medium 社區時,發現了一篇點贊量 1.5k 的文 ...
  • 廢話環節:看過上期文章的小伙伴現在可能還是一頭霧水,怎麼就完成了核心內容,界面呢?哎我說別急讓我先急,博主這不夜以繼日地肝出了界面部分嘛。還是老規矩,不會把所有地方都照顧到,只挑一些有代表性的內容介紹,您各位多擔待🙏。另外博主的JavaFX是跟著B站視頻速成的,指路👉:https://www.b ...
  • ## 目錄 * [1. JUC概述及回顧](#1-juc概述及回顧) * [1.1. JUC是什麼?](#11-juc是什麼) * [1.2. 進程和線程](#12-進程和線程) * [1.3. 並行和併發](#13-並行和併發) * [1.4. wait/sleep的區別](#14-waitsle ...
  • # 🎉Avalonia 11.0.0 正式版發佈! [AvaloniaUI](https://github.com/AvaloniaUI/Avalonia/releases/tag/11.0.0) 發佈11.0.0正式版 終於avalonia發佈了正式版。 ## 更新內容 A11y(輔助功能) 這 ...
  • ​BackgroundImageLayout屬性值 背景圖片重覆:BackgroundImageLayout屬性設置為Tile(預設) 背景圖片左邊顯示:BackgroundImageLayout屬性設置為None 背景圖片右邊顯示:BackgroundImageLayout屬性設置為None,同時 ...
  • FCS一個完整的數據集主要有以下幾部分: 頭段(必須) 從數據集的第一個位元組開始,文件的第一個數據集是從文件的第一個位元組開始,最小長度為58個位元組。 以ASCII碼解析。 記錄內容包括文件版本號(0~5共6位元組)、文本段開始位元組位(10~17共8位元組)、文本段結束位元組位(18~25共8位元組)、數據段 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...