架构师_程序员_码农网

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

查看: 3203|回复: 4

[资料] 【WebView2】(二)WinForm 引入 WebView2 显示 Web 内容

[复制链接]
发表于 2022-9-25 23:02:27 | 显示全部楼层 |阅读模式
需求:使用 VS 2022 新建一个 .NET Framework 4.7.2 的 WinForm 项目,引用 Microsoft.Web.WebView2 SDK 包,使用 WebView2 控件显示和渲染 Web 应用。Microsoft Edge WebView2 控件允许在本机应用中嵌入 web 技术(HTML、CSS 以及 JavaScript)。 WebView2 控件使用 Microsoft Edge 作为绘制引擎,以在本机应用中显示 web 内容。

回顾:

【WebView2】(一)初识 Microsoft Edge WebView2 技术
https://www.itsvse.com/thread-10361-1-1.html

WebView2 运行时

如果您的 Windows 系统没有安装 WebView2 运行时(Windows 11 系统默认已经安装),第一次需要手动下载,地址:https://developer.microsoft.com/zh-cn/microsoft-edge/webview2/

新建 WinForm 项目

打开 VS 2022 新建一个 .NET Framework 4.7.2 的 WinForm 项目,创建后需要引用 Microsoft.Web.WebView2 包,nuget 命令如下:


在工具箱中,找到 WebView2 Windows Forms Control 下的 WebView2 控件拖动到 Form1 窗体,如下图:

QQ截图20220925210559.jpg

提示:默认情况下,在 Visual Studio 2017 中, WebView2 不会显示在工具箱中。 若要使 WebView2 在工具箱中显示,请选择 “工具 > 选项 > 常规 ”>并将 自动填充工具箱设置设置为 True。

设置 webView21 控件 Dock: Fill,Source:https://www.itsvse.com/,如下图:

QQ截图20220925211300.jpg

启动项目,可以看到 WinForm 应用程序成功加载和显示 Web 内容,如下图:

QQ截图20220925211457.jpg

WinForm 应用程序大小

大家最关心的其中一个问题就是应用程序的大小,新建一个 WinForm 应用程序引用 WebView2 SDK 后,几乎没写任何代码后的程序大小为:1.36M,如下图:


QQ截图20220925225851.jpg

显示 WebView2 运行时版本

如何通过 .NET 程序获取系统是否安装 WebView2 运行时或者 WebView2 运行时的版本呢?代码如下:


QQ截图20220925222538.jpg

调用 GetAvailableBrowserVersionString() 方法异常,就代表没有安装 WebView2 运行时


关于分发应用和 WebView2 运行时,参考:https://learn.microsoft.com/zh-cn/microsoft-edge/webview2/concepts/distribution

启用开发者工具

通过需要将 Web 应用和 WinForm 进行联调的过程中,有时候需要看 dom 元素或者网络资源请求,如何启用开发者工具呢?

可以启动后在 webview2 控件使用 F12 方法打开 DevTools 开发者工具,或者使用如下代码打开:
如下图:

QQ截图20220925224328.jpg

禁用右击菜单和开发者工具

在实际的生产环境中,我们将应用程序客户端部署到客户机器上面的时候,不希望用户能够右击(刷新、查看网页源代码等操作),并且禁用开发者工具和网页缩放控制,代码如下:
QQ截图20220925224537.jpg

Microsoft.Web.WebView2.Core API 文档:https://learn.microsoft.com/zh-cn/dotnet/api/microsoft.web.webview2.core?view=webview2-dotnet-1.0.1343.22
Microsoft.Web.WebView2.WinForms API 文档:https://learn.microsoft.com/zh-cn/dotnet/api/microsoft.web.webview2.winforms?view=webview2-dotnet-1.0.1343.22

源码下载:

游客,如果您要查看本帖隐藏内容请回复


(完)






上一篇:【WebView2】(一)初识 Microsoft Edge WebView2 技术
下一篇:【性能优化】前端之 preconnect、dns-prefetch、preload 特性
码农网,只发表在实践过程中,遇到的技术难题,不误导他人。
发表于 2022-10-8 15:04:43 | 显示全部楼层
学习一下
码农网,只发表在实践过程中,遇到的技术难题,不误导他人。
发表于 2023-3-6 16:28:26 | 显示全部楼层
大佬辛苦,拜读一下
码农网,只发表在实践过程中,遇到的技术难题,不误导他人。
发表于 2023-7-28 16:37:19 | 显示全部楼层
跟大佬学习下
码农网,只发表在实践过程中,遇到的技术难题,不误导他人。
发表于 2023-8-8 09:05:33 | 显示全部楼层
学习一下
码农网,只发表在实践过程中,遇到的技术难题,不误导他人。
您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则

免责声明:
码农网所发布的一切软件、编程资料或者文章仅限用于学习和研究目的;不得将上述内容用于商业或者非法用途,否则,一切后果请用户自负。本站信息来自网络,版权争议与本站无关。您必须在下载后的24个小时之内,从您的电脑中彻底删除上述内容。如果您喜欢该程序,请支持正版软件,购买注册,得到更好的正版服务。如有侵权请邮件与我们联系处理。

Mail To:help@itsvse.com

QQ|手机版|小黑屋|架构师 ( 鲁ICP备14021824号-2 )|网站地图

GMT+8, 2024-4-27 20:50

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

快速回复 返回顶部 返回列表