如何用Web技术开发Windows Form应用

简介: 随着Node.js和Ionic等框架的出现,现在感觉JavaScript有一统Web、Mobile、PC三大平台应用开发的能力。在Windows Form 上,利用开源浏览器内核Chromium Embedded Framework (CEF),CEF可以实现C#调用JS,JS调用C#,可以很好的与Web进行应用交互。

      现在H5很热,很多互联网公司的产品都采用混合编程,其中各个平台客户端的“壳”为原生控件,但是内容很多都是Web网页,因此可以做出很多炫酷的效果。随着Node.js和Ionic等框架的出现,现在感觉JavaScript有一统Web、Mobile、PC三大平台应用开发的能力。在Windows Form 上,利用开源浏览器内核Chromium Embedded Framework (CEF),CEF可以实现C#调用JS,JS调用C#,可以很好的与Web进行应用交互。下面用一个简单的例子来说明。

1 项目库


新建一个Windows Form项目,并用NuGet包管理器下载需要的库cefsharp,具体如下图所示:

1.jpg注意:cefsharp必须生成32或者64位的应用程序,这里请自行配置。

2  代码实现


  为了界面好看,这里用到一个MaterialSkin框架来美化UI,可以利用同样的方法进行下载。由于此处用到了MaterialSkin库,它会将窗体的边框隐藏,并自行实现了一个窗体边框。如果直接将ChromiumWebBrowser控件实例化后添加到窗体上,会出现显示不全的问题。为了解决这个问题,在窗体上放入一个panel,调整到合适大小,将ChromiumWebBrowser控件实例化后添加到panel中即可。示例核心代码如下所示:

usingSystem;
usingSystem.Collections.Generic;
usingSystem.ComponentModel;
usingSystem.Data;
usingSystem.Drawing;
usingSystem.Linq;
usingSystem.Text;
usingSystem.Threading.Tasks;
usingSystem.Windows.Forms;
usingCefSharp;
usingCefSharp.WinForms;
usingMaterialSkin;
usingMaterialSkin.Controls;
namespacecefWinForm{
publicpartialclassForm1:MaterialForm    {
privateChromiumWebBrowsermyBrowser=null;
publicForm1()
        {
InitializeComponent();
ChromeDevToolsSystemMenu.CreateSysMenu(this);
varmaterialSkinManager=MaterialSkinManager.Instance;
materialSkinManager.AddFormToManage(this);
materialSkinManager.Theme=MaterialSkinManager.Themes.LIGHT;
materialSkinManager.ColorScheme=newColorScheme(Primary.BlueGrey800, Primary.BlueGrey900, Primary.BlueGrey500, Accent.LightBlue200, TextShade.WHITE);
        }
//Note: The function calls Cef.Initialize(); and Cef.Shutdown();//only need to be called once in the application.privatevoidForm1_Load(objectsender, EventArgse)
        {
Cef.Initialize();
myBrowser=newChromiumWebBrowser("http://127.0.0.1/");
myBrowser.BrowserSettings.DefaultFontSize=12;
//myBrowser.BrowserSettings.AcceptLanguageList = "zh-CN,en-US";// this.Controls.Add(myBrowser);this.pcontainer.Controls.Add(myBrowser);
        }
privatevoidForm1_FormClosing(objectsender, FormClosingEventArgse)
        {
//在退出主程序时,需要首先关闭CefCef.Shutdown();
        }
privatevoiddevToolsToolStripMenuItem_Click(objectsender, EventArgse)
        {
if (myBrowser!=null)
            {
//开发者工具myBrowser.ShowDevTools();
            }
        }
privatevoiddevToolsToolStripMenuItem1_Click(objectsender, EventArgse)
        {
if (myBrowser!=null)
            {
myBrowser.ShowDevTools();
            }
        }
protectedoverridevoidWndProc(refMessagem)
        {
base.WndProc(refm);
// Test if the About item was selected from the system menuif ((m.Msg==ChromeDevToolsSystemMenu.WM_SYSCOMMAND) &&               ((int)m.WParam==ChromeDevToolsSystemMenu.SYSMENU_CHROME_DEV_TOOLS))
            {
myBrowser.ShowDevTools();
            }
        }
    }
}

 这里用new ChromiumWebBrowser("http://127.0.0.1/")创建了一个基于Chromium的WebBrowser,地址为http://127.0.0.1/,这样就相当于本地的一个浏览器。基于H5创建的程序,有一个天然的好处就是,程序的更新可以在服务器端完成,客户端无需升级,即可完成功能的迭代。另外,就是基于CEF框架,内置的浏览器版本,相对可控,这样也从另一方面,解决了传统Web应用兼容多种浏览器的相关问题。

3 效果


运行此示例,相关界面如下所示:

2.jpg

相关文章
|
6月前
|
开发框架 监控 安全
Windows Defender 导致 Web IIS 服务异常停止排查
某日凌晨IIS服务异常停止,经查为Windows Defender安全补丁KB2267602触发引擎更新,导致系统资源波动,进而引发应用池回收。确认非人为操作,系统无重启。通过分析日志与监控,定位原因为Defender更新后扫描加重负载。解决方案:将IIS及.NET相关路径添加至Defender排除列表,避免业务影响。
688 116
|
11月前
|
前端开发 算法 API
构建高性能图像处理Web应用:Next.js与TailwindCSS实践
本文分享了构建在线图像黑白转换工具的技术实践,涵盖技术栈选择、架构设计与性能优化。项目采用Next.js提供优秀的SSR性能和SEO支持,TailwindCSS加速UI开发,WebAssembly实现高性能图像处理算法。通过渐进式处理、WebWorker隔离及内存管理等策略,解决大图像处理性能瓶颈,并确保跨浏览器兼容性和移动设备优化。实际应用案例展示了其即时处理、高质量输出和客户端隐私保护等特点。未来计划引入WebGPU加速、AI增强等功能,进一步提升用户体验。此技术栈为Web图像处理应用提供了高效可行的解决方案。
|
6月前
|
Ubuntu API C++
C++标准库、Windows API及Ubuntu API的综合应用
总之,C++标准库、Windows API和Ubuntu API的综合应用是一项挑战性较大的任务,需要开发者具备跨平台编程的深入知识和丰富经验。通过合理的架构设计和有效的工具选择,可以在不同的操作系统平台上高效地开发和部署应用程序。
257 11
|
6月前
|
Java 测试技术 网络安全
Burp Suite Professional 2025.10 for Windows x64 - 领先的 Web 渗透测试软件
Burp Suite Professional 2025.10 for Windows x64 - 领先的 Web 渗透测试软件
279 0
Burp Suite Professional 2025.10 for Windows x64 - 领先的 Web 渗透测试软件
|
9月前
|
安全 Linux iOS开发
Burp Suite Professional 2025.7 (macOS, Linux, Windows) - Web 应用安全、测试和扫描
Burp Suite Professional 2025.7 (macOS, Linux, Windows) - Web 应用安全、测试和扫描
712 0
Burp Suite Professional 2025.7 (macOS, Linux, Windows) - Web 应用安全、测试和扫描
|
11月前
|
人工智能 安全 网络安全
Burp Suite Professional 2025.5 for Windows x64 - 领先的 Web 渗透测试软件
Burp Suite Professional 2025.5 for Windows x64 - 领先的 Web 渗透测试软件
535 4
Burp Suite Professional 2025.5 for Windows x64 - 领先的 Web 渗透测试软件
|
10月前
|
缓存 前端开发 应用服务中间件
Web端实时通信技术SSE在携程机票业务中的实践应用
本文介绍了携程机票前端基于Server-Sent Events(SSE)实现服务端推送的企业级全链路通用技术解决方案。文章深入探讨了 SSE 技术在应用过程中包括方案对比、技术选型、链路层优化以及实际效果等多维度的技术细节,为类似使用场景提供普适性参考和借鉴。该方案设计目标是实现通用性,适用于各种网络架构和业务场景。
316 1
|
11月前
|
缓存 前端开发 应用服务中间件
Web端实时通信技术SSE在携程机票业务中的实践应用
本文介绍了携程机票前端基于Server-Sent Events(SSE)实现服务端推送的企业级全链路通用技术解决方案。文章深入探讨了 SSE 技术在应用过程中包括方案对比、技术选型、链路层优化以及实际效果等多维度的技术细节,为类似使用场景提供普适性参考和借鉴。
411 7
|
11月前
|
安全 Devops 测试技术
AppSpider 7.5.018 for Windows - Web 应用程序安全测试
AppSpider 7.5.018 for Windows - Web 应用程序安全测试
218 0
AppSpider 7.5.018 for Windows - Web 应用程序安全测试
|
人工智能 Linux iOS开发
Burp Suite Professional 2025.2 (macOS, Linux, Windows) - Web 应用安全、测试和扫描
Burp Suite Professional 2025.2 (macOS, Linux, Windows) - Web 应用安全、测试和扫描
772 12
Burp Suite Professional 2025.2 (macOS, Linux, Windows) - Web 应用安全、测试和扫描