net网站建设(.NET混合开发解决方案10)

WebView2控件应用详解系列博客.NET桌面程序集成Web网页开发的十种解决方案.NET混合开发解决方案1 WebView2简介.NET混合开发解决方案2 WebView2与Edge浏览器的区别.NET混合开发解决方案3 WebView2的进程模型.NET混合开发解决方案4 WebView2的线程模型.NET混合开发解决方案5 WebView2运行时与分发应用.NET混合开发解决方案6 检测是否已安装合适的WebView2运行时.NET混合开发解决方案7 WinForm程序中通过NuGet引用WebView2控件.NET混合开发解决方案8 WinForm程序中集成WebView2控件方案2.NET混合开发解决方案9 WebView2控件的导航事件  客户端程序(WinForm、WPF、Win32、WinUI)集成WebView控件加载Web完成后,还有两种常见的需求C#调用JS方法执行通用方法,设置网页特效。调用网页中定义的JS方法,执行计算等。JS调用C#方法本文讲解第一种需求的实现方式。WebView2控件提供了2个方法用于执行JavaScript脚本ExecuteScriptAsync 在 WebView2 控件中运行 JavaScript。 加载页面文档对象模型(DOM)内容或完成导航后调用此方法。AddScriptToExecuteOnDocumentCreatedAsync创建 DOM 时,在每个页面上运行。 初始化 CoreWebView2 后调用此方法。ExecuteScriptAsync() 执行自定义脚本  由于ExecuteScriptAsync()的结果是JSON编码的,所以如果计算JavaScript的结果是一个字符串,那么将收到一个JSON编码的字符串,而不是字符串的值。例如,以下代码执行导致字符串的脚本。 生成的字符串包括开头的引号、末尾的引号和转义斜杠:如果从脚本调用 JSON.stringify ,则结果将作为 JSON 字符串进行双重编码,其值为 JSON 字符串。只有直接在结果中的属性包含在 JSON 编码的对象中;继承的属性不包括在 JSON 编码的对象中。 大多数 DOM 对象继承所有属性,因此需要将它们的值显式复制到另一个对象中才能返回。 例如:执行 performance.memory 返回时由于所有属性都是继承的,因此在结果中看不到其任何属性。如果改为将特定属性值从 performance.memory 复制到自己的新对象中返回,则会在结果中看到这些属性。(() => { const {totalJSHeapSize, usedJSHeapSize} = performance.memory; return {totalJSHeapSize, usedJSHeapSize}; })();通过 ExecuteScriptAsync()执行脚本时,会在全局上下文中运行。 将脚本置于匿名函数中有助于使定义的任何变量不会污染全局上下文。ExecuteScriptAsync() 执行专用脚本文件  如果将js的逻辑写在字符串中,相对来说写的时候比较困难,如没有语法提示、逻辑检查等,因此很难在Visual Studio中编写大量代码。若要解决此问题,请使用代码创建单独的 JavaScript 文件,然后使用参数传递对该文件的 ExecuteScriptAsync 引用。1、在项目中创建JS文件,并添加要运行的 JavaScript 代码。如 script.js。2、将 JavaScript 文件转换为传递到 ExecuteScriptAsync的字符串,方法是在页面导航完成后粘贴以下代码:string text = System.IO.File.ReadAllText(@"C:\XXXX\script.js");3、使用以下方法 ExecuteScriptAsync传递文本变量:await webView.CoreWebView2.ExecuteScriptAsync(text);ExecuteScriptAsync() 执行目标网页中的JS方法1、新建一个WebFom项目调整页面逻辑运行程序并测试WebView2调用JS方法的逻辑特别提醒调用目标JS方法时,如果参数是字符串类型,则需要使用单引号包裹AddScriptToExecuteOnDocumentCreatedAsync() 设置网页特效WebView2控件加载网页后,如果将一个文件(如:script.js、script.txt等)拖拽到WebView2控件上,将自动执行文件,效果如下可以通过webView.CoreWebView2.AddScriptToExecuteOnDocumentCreatedAsync()方法运行脚本禁用拖拽功能await webView.CoreWebView2.AddScriptToExecuteOnDocumentCreatedAsync(
"window.addEventListener('dragover',function(e){e.preventDefault();},false);" +
"window.addEventListener('drop',function(e){" +
"e.preventDefault();" +
"console.log(e.dataTransfer);" +
"console.log(e.dataTransfer.files[0])" +
"}, false);");再次运行后,拖拽文件为WebView2控件上无任何反应,说明拖拽功能已被禁用使用 webView2.CoreWebView2.ExecuteScriptAsync() 方法执行上述脚本同样可以达到相同的效果。还可以执行脚本来禁用网页右键菜单功能await webView.CoreWebView2.ExecuteScriptAsync("window.addEventListener('contextmenu', window => {window.preventDefault();});");开发者还可以执行其他自定义脚本来设置网页的效果。欢迎关注、转发、交流。每天分享优质IT内容。#四川雅安发生4.8级地震##郑大回应女生私自外出感染新冠被立案##中国男子接力队获东京奥运铜牌##美日五艘航母围堵辽宁舰?专家解读##今年夏粮最低收购价全面提高#

本文出自快速备案,转载时请注明出处及相应链接。

本文永久链接: https://www.175ku.com/33750.html