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

news/2025/2/25 15:59:04

以下是一个可行的解决方案,能够满足使用 .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.js 或 vue.config.js,确保构建输出目录为 .NET Core 项目的 wwwroot 目录。
    例如:

    javascript

    export default defineConfig({
      build: {
        outDir: '../wwwroot/vue', // 将构建输出到 .NET Core 的 wwwroot/vue 目录
      },
    });
4. 配置 .NET Core 项目
  • 在 .NET Core 项目中,修改 Program.cs 或 Startup.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 项目中,实现一次发布部署的目标。


http://www.niftyadmin.cn/n/5845881.html

相关文章

web第二次作业

一.后台管理系统首页代码 1.html代码 <!DOCTYPE html> <html lang"en"> <head> <meta charset"UTF-8"> <meta name"viewport" content"widthdevice-width, initial-scale1.0"> <title>实验&l…

如今物联网的快速发展对hmi的更新有哪些积极影响

一、功能更加丰富 物联网的快速发展使得 HMI&#xff08;人机界面&#xff09;能够连接更多的设备和系统&#xff0c;从而实现更加丰富的功能。例如&#xff0c;通过与传感器网络的连接&#xff0c;HMI 可以实时显示设备的运行状态、环境参数等信息&#xff0c;为用户提供更加…

前端开发架构师Prompt指令的最佳实践

前端开发架构师Prompt 提示词可作为系统提示词使用&#xff0c;可基于用户的需求输出对应的编码方案。 本次提示词偏向前端开发的使用&#xff0c;如有需要可适当修改关键词和示例。 推荐使用 Cursor 中作为自定义指令使用Cline 插件中作为自定义指令使用在力所能及的范围内使…

Opencv操作相关内容记录

关于opencv的安装包 https://www.lfd.uci.edu/~gohlke/pythonlibs/#opencv 机器人相关视频 http://i.youku.com/u/UMTkxNDMxNDkxNg 机器人历史及机器人应用_1 空间描述&#xff0c;广义坐标_2 [第3集] 东芝公司开发的柔性致动器 机器人“蜂鸟”_4 灵长类仿生机器人_5 [第6集…

k8s中,一.service发布服务,二.dashboard:基于网页的k8s管理插件,三.资源服务与帐号权限

一.service资源对内发布服务Cluster IP对外发布服务NodePortIngress 二.dashboard:基于网页的k8s管理插件 三.资源服务与帐号权限一.service:用户无法预知pod的ip地址以及所在的节点,多个相同的pod如何访问他们上面的服务功能:1.服务自动感知:pod迁移后访问service的ip,不受影响…

疯狂前端面试题(二)

一、Webpack的理解 Webpack 是一个现代 JavaScript 应用程序的静态模块打包工具。Webpack 能够将各种资源&#xff08;JavaScript、CSS、图片、字体等&#xff09;视为模块&#xff0c;并通过依赖关系图将这些模块打包成一个或多个最终的输出文件&#xff08;通常是一个或几个…

WPS如何接入DeepSeek(通过第三方工具)

WPS如何接入DeepSeek 一、下载并安装OfficeAI插件二、配置OfficeAI插件三、使用DeepSeek功能 本文介绍如何通过 WPS 的第三方工具调用 DeepSeek 大模型&#xff0c;实现自动化文本扩写、校对和翻译等功能。 一、下载并安装OfficeAI插件 1、访问OfficeAI插件下载地址&#xff…

在阿里云ECS上一键部署DeepSeek-R1

DeepSeek-R1 是一款开源模型&#xff0c;也提供了 API(接口)调用方式。据 DeepSeek介绍&#xff0c;DeepSeek-R1 后训练阶段大规模使用了强化学习技术&#xff0c;在只有极少标注数据的情况下提升了模型推理能力&#xff0c;该模型性能对标 OpenAl o1 正式版。DeepSeek-R1 推出…