如何用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

相关文章
|
2天前
|
设计模式 Rust 安全
深入理解PHP 7的新特性及其对现代Web开发的影响
本文通过数据驱动的分析,探讨了PHP 7的发布如何革新了Web开发的面貌。文章首先概述了PHP 7带来的性能提升与新特性,然后通过实际案例和性能测试数据,详细讨论了这些新特性对提高代码效率、增强安全性和支持现代编程范式的具体影响。最后,文章将评估PHP 7在当前Web开发环境中的地位,并对其未来的发展做出展望。
|
3天前
|
人工智能 开发框架 Devops
.NET技术概览:** 本文探讨了.NET的核心特性,包括多语言支持、Common Language Runtime、丰富的类库和跨平台能力,强调其在企业级、Web、移动及游戏开发中的应用。
【7月更文挑战第4天】.NET技术概览:** 本文探讨了.NET的核心特性,包括多语言支持、Common Language Runtime、丰富的类库和跨平台能力,强调其在企业级、Web、移动及游戏开发中的应用。此外,讨论了.NET如何通过性能优化、DevOps集成、AI与ML支持以及开源策略应对未来挑战,为开发者提供强大工具,共创软件开发新篇章。
11 3
|
3天前
|
JavaScript 前端开发
web应用的生命周期
web应用的生命周期
9 1
|
2天前
|
Java 应用服务中间件 Linux
Tomcat安装部署[单机软件],可以让用户开发的WEB应用程序,变成可以被访问的网页,Tomcat的使用需要jdk环境
Tomcat安装部署[单机软件],可以让用户开发的WEB应用程序,变成可以被访问的网页,Tomcat的使用需要jdk环境
|
2天前
|
JSON 安全 编译器
PHP 8的新特性及其对现代Web开发的影响
随着PHP 8的发布,这一流行的服务器端脚本语言带来了诸多改进和新增特性,这些变化不仅提升了语言本身的性能和安全性,还对现代Web开发实践产生了深远影响。本文将深入探讨PHP 8的关键新特性,包括JIT编译器、联合类型、命名参数、匹配表达式等,并分析它们如何优化代码编写、强化类型安全以及提高执行效率。同时,我们还将讨论这些新特性对开发者构建更快、更可靠应用程序的能力所产生的积极效应。
6 0
|
2天前
|
数据采集 机器学习/深度学习 数据可视化
Jupyter Notebooks和IPython是交互式数据分析利器,提升效率。Jupyter是开源Web应用
【7月更文挑战第5天】Jupyter Notebooks和IPython是交互式数据分析利器,提升效率。Jupyter是开源Web应用,支持多语言,结合IPython的交互式解释器,便于编程和科学计算。两者提供即时反馈、丰富库支持、跨语言功能及协作共享。基本流程包括:数据导入(使用Pandas)、预处理、分析(借助Pandas、NumPy、Matplotlib)、模型训练(如随机森林)和评估。
9 0
|
3天前
|
IDE 编译器 测试技术
PHP 8新特性解析及其对现代Web开发的影响
本文深入探讨了PHP 8版本中引入的新特性,并分析了这些变化如何影响现代Web开发的实践。通过引用最新的性能测试数据和开发者社区反馈,本文揭示了PHP 8在提升开发效率、增强代码安全性及优化性能方面所做出的贡献。同时,文章还讨论了PHP 8新特性对于现有项目升级路径的实际指导意义,为读者提供了关于是否以及如何迁移至PHP 8的洞见。
8 0
|
3天前
|
搜索推荐 编译器 测试技术
PHP 8新特性及其对现代Web开发的影响
随着PHP 8的发布,开发者社区迎来了一系列创新特性,这些特性旨在提升语言性能、增强类型系统并改进错误处理机制。本文将深入探讨PHP 8中的JIT编译器、联合类型、错误处理等关键更新,并通过实证数据展示这些变化如何优化代码执行和提高开发效率。我们将通过案例分析,阐述新特性在实际项目中的应用,以及它们如何影响未来PHP Web开发的走向。
|
Web App开发 JavaScript 前端开发
《单页Web应用:JavaScript从前端到后端》——1.3 精心编写的单页应用的用户效益
所有这些好处意味着,你可能会想把下个应用做成单页应用。每次点击后都会重新渲染整张页面的笨拙网站,容易日益疏远富有经验的用户。精心编写的单页应用具有互动和快速响应的界面,还伴有访问网络的功能,这将帮助我们把客户留在属于他们的地方:使用我们的产品。
1162 0