.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 项目中,实现一次发布部署的目标。

相关推荐
李鸿耀2 小时前
主题换肤指南:设计到开发的完整实践
前端
带娃的IT创业者7 小时前
TypeScript + React + Ant Design 前端架构入门:搭建一个 Flask 个人博客前端
前端·react.js·typescript
非凡ghost8 小时前
MPC-BE视频播放器(强大视频播放器) 中文绿色版
前端·windows·音视频·软件需求
Stanford_11068 小时前
React前端框架有哪些?
前端·微信小程序·前端框架·微信公众平台·twitter·微信开放平台
洛可可白8 小时前
把 Vue2 项目“黑盒”嵌进 Vue3:qiankun 微前端实战笔记
前端·vue.js·笔记
学习同学9 小时前
从0到1制作一个go语言游戏服务器(二)web服务搭建
服务器·前端·golang
-D调定义之崽崽9 小时前
【初学】调试 MCP Server
前端·mcp
四月_h9 小时前
vue2动态实现多Y轴echarts图表,及节点点击事件
前端·javascript·vue.js·echarts
csdn_aspnet10 小时前
使用 Entity Framework Code First 方法创建 ASP.NET Core 5.0 Web API
.netcore·webapi
小先生81210 小时前
.NET Core项目中 Serilog日志文件配置
c#·.netcore