首页
学习
活动
专区
圈层
工具
发布
社区首页 >专栏 >使用 NanUI 快速创建具有现代用户界面的 WinForm 应用程序

使用 NanUI 快速创建具有现代用户界面的 WinForm 应用程序

作者头像
追逐时光者
发布2026-02-04 09:47:35
发布2026-02-04 09:47:35
1540
举报
文章被收录于专栏:编程进阶实战编程进阶实战

前言

今天大姚给大家分享一个强大的 .NET 开源框架,它利用 Web 技术(HTML5、CSS3、JavaScript)为 WinForm 应用程序构建现代化的用户界面:NanUI。

如果你正在寻找一个用于创建具有现代用户界面的 WinForm 应用程序的框架,NanUI 是一个不错的选择。

项目介绍

NanUI 是一个基于 .NET 平台的开源(MIT License)框架,旨在帮助开发者使用 HTML5、CSS3 和 JavaScript 构建具有现代感的 WinForm 应用程序用户界面。它底层依托于 Xilium.CefGlue 这是 Chromium Embedded Framework(CEF)在 .NET 环境下的官方绑定实现,通过嵌入完整的 Chromium 渲染引擎,使 WinForm 应用能够呈现 Web 技术驱动的富交互界面。

基本原理

官方介绍:

image
image

基本原理概括:

  • Chromium Embedded Framework (CEF) 是一个开源项目,一个用于将基于 Chromium 的浏览器嵌入其他应用程序的简单框架。
  • 它提供稳定的 C/C++ API,支持多进程架构(Browser 进程 + Renderer/GPU 等子进程),具备完整的 HTML5 渲染、JavaScript 执行、网络请求、安全沙箱等能力。
  • NanUI 并未直接调用 CEF 的 C 接口,而是基于 Xilium.CefGlue 这是一个高质量的 .NET 封装库,将 CEF 的 C++ API 转换为 C# 可调用的托管接口。

环境要求

开发环境

  • Visual Studio 2019 或更高版本。
  • NET Framework 4.6.2 或更高版本 / .NET 6.0 或更高版本。

部署环境

  • .NET Framework 4.6.2 或更高版本。
  • .NET 6.0 需要 Windows 7 Service Pack 1 或更高版本。
  • .NET 7.0/8.0/9.0 需要 Windows 10 或 Windows 11。
  • Microsoft Windows 7 Service Pack 1 或更高版本。

项目源代码

image
image

快速使用

创建一个 WinForm 应用程序

首先我们快速创建一个名为NanUIExercise Windows 窗体应用程序:

image
image
image
image
image
image

安装 NanUI NuGet 包

安装 NanUINetDimension.NanUI

image
image

安装 NanUI 所依赖的 Chromium Embedded Framework 依赖包 NetDimension.NanUI.Runtime

image
image

创建一个基本的 NanUI 应用程序

Program.cs:

代码语言:javascript
复制
using NetDimension.NanUI;

namespace NanUIExercise
{
    internal static class Program
    {
        /// <summary>
        ///  The main entry point for the application.
        /// </summary>
        [STAThread]
        static void Main()
        {
            var builder = NanUIApp.CreateBuilder();

            builder.UseNanUIApp<MyFirstAPP>();

            var app = builder.Build();

            app.Run();
        }
    }
}

创建一个类继承 AppStartup 来配置应用程序:

代码语言:javascript
复制
using Microsoft.Extensions.DependencyInjection;
using NetDimension.NanUI;

namespace NanUIExercise
{
    public class MyFirstAPP : AppStartup
    {
        protected override MainWindowCreationAction? UseMainWindow(MainWindowOptions opts)
        {
            // 设置应用程序的主窗体
            return opts.UseMainFormium<MyWindow>();
        }

        protected override void ProgramMain(string[] args)
        {
            // Main函数中的代码应该在这里,该函数只在主进程中运行。这样可以防止子进程运行一些不正确的初始化代码。
            ApplicationConfiguration.Initialize();
        }

        protected override void ConfigurationChromiumEmbedded(ChromiumEnvironmentBuiler cef)
        {
            // 在此处配置 Chromium Embedded Framwork
        }

        protected override void ConfigureServices(IServiceCollection services)
        {
            // 在这里配置该应用程序的服务
        }
    }
}

创建一个类实现 Formium,用于配置应用程序的主窗口:

代码语言:javascript
复制
using NetDimension.NanUI;
using NetDimension.NanUI.Forms;

namespace NanUIExercise
{
    public class MyWindow : Formium
    {
        public MyWindow()
        {
            Url = "https://juejin.cn/";
        }

        protected override FormStyle ConfigureWindowStyle(WindowStyleBuilder builder)
        {
            // 此处配置窗口的样式和属性,或留空以使用默认样式

            var style = builder.UseSystemForm();

            style.TitleBar = false;

            style.DefaultAppTitle = "My First NanUI App";

            return style;
        }
    }
}

运行效果查看:

image
image
image
image

项目源码地址

更多项目实用功能和特性欢迎前往项目开源地址查看👀,别忘了给项目一个Star支持💖。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2026-02-03,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 前言
  • 项目介绍
  • 基本原理
  • 环境要求
    • 开发环境
    • 部署环境
  • 项目源代码
  • 快速使用
    • 创建一个 WinForm 应用程序
    • 安装 NanUI NuGet 包
    • 创建一个基本的 NanUI 应用程序
  • 项目源码地址
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档