我正在尝试创建一个使用WebView2 WPF 组件的应用程序。目前,我正在记录由网站的 javascript 代码使用console.log()
.
这就是我现在所拥有的:
public partial class WebView2BrowserControl : WebView2
{
private async void OnWebViewLoaded(object sender, RoutedEventArgs e)
{
await EnsureCoreWebView2Async();
if (showDeveloperTools)
{
CoreWebView2.GetDevToolsProtocolEventReceiver("Log.entryAdded").DevToolsProtocolEventReceived += OnConsoleMessage;
CoreWebView2.OpenDevToolsWindow();
}
else
{
CoreWebView2.Settings.AreDevToolsEnabled = false;
}
}
private void OnConsoleMessage(object sender, CoreWebView2DevToolsProtocolEventReceivedEventArgs e)
{
if (e != null && e.ParameterObjectAsJson != null)
{
Trace.WriteLine("WebView2:" + e.ParameterObjectAsJson);
}
}
}
如您所见,我使用GetDevToolsProtocolEventReceiver方法来订阅 DevTools 中的事件。该文档指出以下内容:
eventName:String - 事件的全名,格式为 {domain}.{event}。 有关 DevToolsProtocol 事件描述和事件参数的更多信息,请导航到 DevTools 协议查看器。
...根据DevTools 协议查看器,我正在寻找的事件是Log.entryAdded。
现在的问题是,虽然GetDevToolsProtocolEventReceiver("Log.entryAdded")
调用不会引发任何异常,但事件永远不会引发,即使我可以看到 DevTools 中记录的内容。console.log()
我什至尝试在 DevTools 窗口中编写自己的调用。
我尝试过的其他事情:
- 使用在机器上安装 WebView2 的 Evergreen 独立安装程序或基本上是 WebView2 的便携式版本的固定版本(87 和 88 版本)
- 使用来自 NuGet 的 Microsoft.Web.View2.Core.dll 的最新稳定版本 1.0.705.50 和最新的预发布版本
- 同时使用 Log.entryAdded 事件和 Console.messageAdded(已弃用)
- 打开 DevTools 窗口后订阅事件
那么我做错了什么?