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

相关文章
|
16天前
|
前端开发 JavaScript 安全
前端性能调优:HTTP/2与HTTPS在Web加速中的应用
【10月更文挑战第27天】本文介绍了HTTP/2和HTTPS在前端性能调优中的应用。通过多路复用、服务器推送和头部压缩等特性,HTTP/2显著提升了Web性能。同时,HTTPS确保了数据传输的安全性。文章提供了示例代码,展示了如何使用Node.js创建一个HTTP/2服务器。
30 3
|
16天前
|
设计模式 前端开发 数据库
Python Web开发:Django框架下的全栈开发实战
【10月更文挑战第27天】本文介绍了Django框架在Python Web开发中的应用,涵盖了Django与Flask等框架的比较、项目结构、模型、视图、模板和URL配置等内容,并展示了实际代码示例,帮助读者快速掌握Django全栈开发的核心技术。
103 45
|
8天前
|
安全 前端开发 Windows
Windows Electron 应用更新的原理是什么?揭秘 NsisUpdater
本文介绍了 Electron 应用在 Windows 中的更新原理,重点分析了 `NsisUpdater` 类的实现。该类利用 NSIS 脚本,通过初始化、检查更新、下载更新、验证签名和安装更新等步骤,确保应用的更新过程安全可靠。核心功能包括差异下载、签名验证和管理员权限处理,确保更新高效且安全。
21 4
Windows Electron 应用更新的原理是什么?揭秘 NsisUpdater
|
3天前
|
缓存 安全 网络安全
HTTP/2与HTTPS在Web加速中的应用
HTTP/2与HTTPS在Web加速中的应用
|
6天前
|
SQL 安全 前端开发
PHP与现代Web开发:构建高效的网络应用
【10月更文挑战第37天】在数字化时代,PHP作为一门强大的服务器端脚本语言,持续影响着Web开发的面貌。本文将深入探讨PHP在现代Web开发中的角色,包括其核心优势、面临的挑战以及如何利用PHP构建高效、安全的网络应用。通过具体代码示例和最佳实践的分享,旨在为开发者提供实用指南,帮助他们在不断变化的技术环境中保持竞争力。
|
11天前
|
前端开发 API 开发者
Python Web开发者必看!AJAX、Fetch API实战技巧,让前后端交互如丝般顺滑!
在Web开发中,前后端的高效交互是提升用户体验的关键。本文通过一个基于Flask框架的博客系统实战案例,详细介绍了如何使用AJAX和Fetch API实现不刷新页面查看评论的功能。从后端路由设置到前端请求处理,全面展示了这两种技术的应用技巧,帮助Python Web开发者提升项目质量和开发效率。
26 1
|
14天前
|
XML 安全 PHP
PHP与SOAP Web服务开发:基础与进阶教程
本文介绍了PHP与SOAP Web服务的基础和进阶知识,涵盖SOAP的基本概念、PHP中的SoapServer和SoapClient类的使用方法,以及服务端和客户端的开发示例。此外,还探讨了安全性、性能优化等高级主题,帮助开发者掌握更高效的Web服务开发技巧。
|
17天前
|
前端开发 安全 应用服务中间件
前端性能调优:HTTP/2与HTTPS在Web加速中的应用
【10月更文挑战第26天】随着互联网的快速发展,前端性能调优成为开发者的重要任务。本文探讨了HTTP/2与HTTPS在前端性能优化中的应用,介绍了二进制分帧、多路复用和服务器推送等特性,并通过Nginx配置示例展示了如何启用HTTP/2和HTTPS,以提升Web应用的性能和安全性。
17 3
|
17天前
|
安全 数据库 开发者
Python Web开发:Django框架下的全栈开发实战
【10月更文挑战第26天】本文详细介绍了如何在Django框架下进行全栈开发,包括环境安装与配置、创建项目和应用、定义模型类、运行数据库迁移、创建视图和URL映射、编写模板以及启动开发服务器等步骤,并通过示例代码展示了具体实现过程。
29 2
|
Windows
windows form (窗体) 之间传值小结
在windows form之间传值,我总结了有四个方法:全局变量、属性、窗体构造函数和delegate。 第一个全局变量: 这个最简单,只要把变量描述成static就可以了,在form2中直接引用form1的变量,代码如下: 在form1中定义一个static变量public static i...
834 0

热门文章

最新文章