WinForm程序嵌入Web网页

文章目录


前言

由于此项目需要winform客户端嵌入web网页并于JAVA端交互数据,所以研究了一下嵌入web网页这部分,趟了一遍雷,这里做下记录。


一、三方库或控件的选择测试

1 .首先是用了 WebBrowser 控件,发现可以打开部分页面,但是有很多页面打不开,性能相对较弱,支持感觉很拉跨,于是弃用了换其他的。

2 .然后用了 Microsoft Edge WebView2 这个做demo测试,兼容性较好,我所需要的页面都可以打开,通过NeGet安装SDK,DLL尺寸较小,对项目安装包大小几乎没有影响。

最后我选择的这个,后续会讲一下安装使用步骤。

3 .CefSharp也通过NeGet安装SDK,也可以打开我需要的所有页面,不足的是运行时环境+SDK包比较大,看网络上说此库兼容性、支持性要比 Microsoft Edge WebView2 强大,我没要做更多的测试,感兴趣的可以自己写个demo试试。

二、Microsoft Edge WebView2安装、使用步骤

1.安装

通过NeGet安装SDK,安装后VS2019的winform工具箱中是没有自动出现控件的,(也有幸运的,安装完就有了)

安装完后手动添加控件

点击工具箱空白处鼠标右击,点击选择项

点击浏览找到你上面NeGet安装的Microsoft Edge WebView2 的SDK文件夹,选择红框中的 dll 点击确定就添加上了

添加成功后如下图就可以使用了

2.使用

和平常控件一样拖动使用,设置上你的 url 就可以了

注意:
如果你的 url 通过代码设置,WebView2控件一定不要在设计器里拖动添加,必须去代码里添加WebView2实例化,否则会报错说你还没有初始化控件就是用。

简单代码:

csharp 复制代码
using Microsoft.Web.WebView2.WinForms;

private WebView2 webView;//Web
public void WebViewInit()
{
   this.webView = new WebView2();
   // 设置 WebView2 的大小和位置
   webView.Location = new Point(50, 70); // 设置初始位置
   webView.Size = new Size(1400, 700);  // 设置初始大小

   // 将控件添加到窗体
   Controls.Add(webView);
   // 在窗体加载时导航到指定的网页
   string url = "http://192.168.1.60/?t=" + DateTime.Now.Ticks;
  // 初始化 WebView2 控件并加载网页
  InitializeWebView2AndLoadPage(url); 
}


private async void InitializeWebView2AndLoadPage(string url)
        {
            // 确保 CoreWebView2 实例已经准备好
            await webView.EnsureCoreWebView2Async();

            // 确保在 WebView2 控件初始化完成后加载网页
            webView.CoreWebView2.Navigate(url);
        }
相关推荐
c#上位机12 小时前
wpf之MVVM中只读属性更新界面
c#·wpf·mvvm
技术支持者python,php14 小时前
winform本地上位机-ModbusRTC1.上位机控制台与数据监控(数据监控架构思维与图表系列)
c#
kalvin_y_liu17 小时前
DeploySharp开源发布:让C#部署深度学习模型更加简单
深度学习·开源·c#
c#上位机17 小时前
wpf之GroupBox
c#·wpf
CodeCraft Studio18 小时前
国产化PDF处理控件Spire.PDF教程:C#中轻松修改 PDF 文档内容
前端·pdf·c#·.net·spire.pdf·编辑pdf·修改pdf
mit6.82418 小时前
[C# starter-kit] Domain Entities | `AuditableEntity`基类 | 跟踪变化 | 软删除
数据库·microsoft·c#
李宥小哥1 天前
C#基础11-常用类
android·java·c#
偶尔的鼠标人1 天前
Avalonia中,使用DataTable类型作为DataGrid的ItemSource 数据源
ui·c#·avalonia
R-G-B1 天前
【02】大恒相机SDK C#开发 —— 初始化相机,采集第一帧图像
c#·大恒相机sdk·大恒相机初始化·大恒相机采集图像
韩立学长1 天前
【开题答辩实录分享】以《制造型企业供应商档案管理系统设计与开发》为例进行答辩实录分享
sqlserver·c#