.NET Core 8 Blazor 和 Vue 3 技术构建网

以下是一个可行的解决方案,能够满足使用 .NET Core 8 Blazor 和 Vue 3 技术构建网站,并且将前后端代码放在一个站点中,实现一次发布部署的目标。


解决方案概述

  1. 技术栈选择

    • 后端:.NET Core 8 Blazor Server 或 Blazor WebAssembly。

    • 前端:Vue 3(用于前后端分离的部分)。

    • 部署:将 Vue 3 构建后的静态文件嵌入到 .NET Core 项目中,最终发布为一个站点。

  2. 项目结构

    • 将 Vue 3 项目作为 .NET Core 项目的一部分,放在一个解决方案中。

    • Vue 3 项目负责前后端分离的部分,Blazor 负责其他页面或功能。

  3. 开发流程

    • 开发时,Vue 3 项目独立运行,通过 API 与 .NET Core 后端交互。

    • 部署时,将 Vue 3 构建后的静态文件嵌入到 .NET Core 项目中。

  4. 部署流程

    • 使用 .NET Core 的发布命令,将整个站点(包括 Vue 3 的静态文件)打包发布。

详细步骤

1. 创建 .NET Core 8 Blazor 项目

使用 Visual Studio 或命令行工具创建一个 .NET Core 8 Blazor 项目。

  • 如果是 Blazor Server:

    复制代码
    dotnet new blazorserver -n MyBlazorApp
  • 如果是 Blazor WebAssembly:

    复制代码
    dotnet new blazorwasm -n MyBlazorApp
2. 创建 Vue 3 项目

在 .NET Core 项目的根目录下创建一个 Vue 3 项目。

  • 进入 .NET Core 项目目录:

    复制代码
    cd MyBlazorApp
  • 创建 Vue 3 项目:

    复制代码
    npm create vue@latest

    按照提示完成 Vue 3 项目的初始化。

3. 配置 Vue 3 项目
  • 修改 Vue 3 项目的 vite.config.jsvue.config.js,确保构建输出目录为 .NET Core 项目的 wwwroot 目录。

    例如:

    javascript

    复制代码
    export default defineConfig({
      build: {
        outDir: '../wwwroot/vue', // 将构建输出到 .NET Core 的 wwwroot/vue 目录
      },
    });
4. 配置 .NET Core 项目
  • 在 .NET Core 项目中,修改 Program.csStartup.cs,确保能够正确加载 Vue 3 的静态文件。

    例如:

    csharp

    复制代码
    app.UseStaticFiles(); // 启用静态文件支持
  • wwwroot 目录下创建一个 vue 文件夹,用于存放 Vue 3 构建后的静态文件。

5. 开发时运行
  • 开发时,Vue 3 项目独立运行,通过 API 与 .NET Core 后端交互。

    • 启动 .NET Core 项目:

      复制代码
      dotnet run
    • 启动 Vue 3 项目:

      复制代码
      npm run dev
6. 构建和部署
  • 在发布时,先构建 Vue 3 项目,然后将构建后的文件复制到 .NET Core 项目的 wwwroot/vue 目录。

    • 构建 Vue 3 项目:

      复制代码
      npm run build
    • 构建 .NET Core 项目:

      复制代码
      dotnet publish -c Release -o ./publish
  • 最终发布的 publish 目录将包含 .NET Core 后端和 Vue 3 前端的完整站点。

7. 部署到服务器
  • publish 目录中的内容部署到服务器(例如 IIS、Nginx 或 Kestrel)。

  • 确保服务器配置正确,能够处理静态文件和 API 请求。


项目结构示例

复制

复制代码
MyBlazorApp/
├── Client/                  # Vue 3 项目
│   ├── src/
│   ├── public/
│   ├── package.json
│   └── vite.config.js
├── wwwroot/                 # .NET Core 静态文件目录
│   └── vue/                 # Vue 3 构建后的静态文件
├── Pages/                   # Blazor 页面
├── Program.cs               # .NET Core 启动文件
├── MyBlazorApp.csproj       # .NET Core 项目文件
└── ...

注意事项

  1. API 交互

    • Vue 3 项目通过 API 与 .NET Core 后端交互。确保 .NET Core 项目中定义了所需的 API 接口。
  2. 路由冲突

    • 如果 Blazor 和 Vue 3 都使用了前端路由,需要确保路由不会冲突。可以通过 URL 前缀区分(例如 /vue/* 由 Vue 处理,其他由 Blazor 处理)。
  3. 静态文件缓存

    • 在部署时,确保静态文件(如 Vue 3 的 JS 文件)的缓存策略正确,避免浏览器缓存旧版本。
  4. 开发效率

    • 开发时,Vue 3 项目可以独立运行,通过代理与 .NET Core 后端交互,提高开发效率。

总结

通过以上方案,你可以将 .NET Core 8 Blazor 和 Vue 3 技术结合,构建一个前后端代码都在一个站点中的网站。开发时,Vue 3 项目独立运行;部署时,Vue 3 的静态文件嵌入到 .NET Core 项目中,实现一次发布部署的目标。

相关推荐
fanruitian2 小时前
uniapp android开发 测试板本与发行版本
前端·javascript·uni-app
rayufo2 小时前
【工具】列出指定文件夹下所有的目录和文件
开发语言·前端·python
RANCE_atttackkk2 小时前
[Java]实现使用邮箱找回密码的功能
java·开发语言·前端·spring boot·intellij-idea·idea
2501_944525544 小时前
Flutter for OpenHarmony 个人理财管理App实战 - 支出分析页面
android·开发语言·前端·javascript·flutter
李白你好4 小时前
Burp Suite插件用于自动检测Web应用程序中的未授权访问漏洞
前端
刘一说5 小时前
Vue 组件不必要的重新渲染问题解析:为什么子组件总在“无故”刷新?
前端·javascript·vue.js
徐同保6 小时前
React useRef 完全指南:在异步回调中访问最新的 props/state引言
前端·javascript·react.js
fanruitian6 小时前
uniapp 创建项目
javascript·vue.js·uni-app
刘一说7 小时前
Vue 导航守卫未生效问题解析:为什么路由守卫不执行或逻辑失效?
前端·javascript·vue.js
一周七喜h7 小时前
在Vue3和TypeScripts中使用pinia
前端·javascript·vue.js