码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • .NET混合开发解决方案11 WebView2加载的网页中JS调用C#方法


    系列目录     【已更新最新开发文章,点击查看详细】

    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程序中通过设置固定版本运行时的BrowserExecutableFolder属性集成WebView2控件

    .NET混合开发解决方案9 WebView2控件的导航事件

    .NET混合开发解决方案10 WebView2控件调用网页JS方法

      在我的博客《.NET混合开发解决方案10 WebView2控件调用网页JS方法》中介绍了C#调用网页中定义的JavaScript方法以执行某种业务逻辑,同样WebView2控件中加载的网页中自定义的JavaScript方法中也可以调用C#方法。

      WebView2控件通过将对象传递到Web网页,使应用程序能够弥合web和本机应用程序(客户端程序:WinForm、WPF、WinUI、Win32)之间的鸿沟。此类对象在本机代码中定义,通常称为主机对象。可以使用WebView2的AddHostObjectToScript()将它们投影到JavaScript中。

      在开发WebView2应用程序时,需要一个本机对象,它的方法或属性很有用。开发者希望从web端代码触发这些本机对象方法,或者作为应用程序web端用户交互的结果。最主要的是开发者不想也不需要在web端代码中重新实现本机对象的方法。AddHostObjectToScript API支持web端代码重用本机端代码。

      比如在网页中调用客户端电脑的摄像头,如果在Web端开发,则编写大量的代码。如果在本机实现,则非常简单。能够调用本机对象的方法比在应用程序的web端重新编码对象的方法更快、效率更高。在这种情况下,本机端代码可以将对象传递到应用程序的web端JavaScript代码,以便JavaScript代码可以重用本机API的方法。如以下应用场景:

    • 有一个键盘API,你想调用keyboardObject。从web端显示键盘功能。
    • JavaScript是沙盒,限制了它在本机端的能力。例如,如果需要在本机端访问文件,则必须使用本机文件系统。如果您有一个通过AddHostObjectToScript向JavaScript公开的本机对象,则可以使用它来操作本机文件系统上的文件。

    下面通过一个Demo来讲解如何实现JS调用C#方法。

    业务场景:JS调用C#方法,传递三个参数,分别是num1、num2、message。C#接收到参数后将num1与num2进行加法运算,并将计算结果返回给JS方法。

    先看一下示例效果

    下面详细介绍其实现步骤。

    步骤1

    定义一个主机对象,如:CustomWebView2HostObject类,在类中编写方法并实现内部业务逻辑。

    复制代码
    using System.Runtime.InteropServices;
    
    namespace WebView2Demo_WinForm
    {
        /// <summary>
        /// 自定义宿主类,用于向网页注册C#对象,供JS调用
        /// </summary>
        [ClassInterface(ClassInterfaceType.AutoDual)]
        [ComVisible(true)]
        public class CustomWebView2HostObject
        {
            public string TestCalcAddByCsharpMethod(int num1, int num2, string message)
            {
                MessageBox.Show($"C#方法接收到J传入的参数 num1={num1},num2={num2},message={message}", "提示", MessageBoxButtons.OK, MessageBoxIcon.Information);
    
                return "计算结果为:" + (num1 + num2);
            }
        }
    }
    复制代码

    自定义的 CustomWebView2HostObject 类,必须标记 [ClassInterface(ClassInterfaceType.AutoDual)]、[ComVisible(true)] 特性,否则JS无法访问到该类

    C#方法与平时写的代码完全一样。

    步骤2

    在访问目标网页之前,通过webView2.CoreWebView2.AddHostObjectToScript()方法向网页中注入主机对象,其中第一个参数是自定义名称(随意命名),JS中访问主机对象时就需要与该参数名称一致。

    步骤3

    网页中定义一个测试按钮,并设置点击事件

    点击事件中,第31行获取主机对象,customWebView2HostObject 与 C#中定义的名称需要完全相同。

    使用主机对象调用C#方法,由于调用过程是异步的,所以需要使用 await,方法定义前需要加上 async。

    以上三步完成后即实现了JS访问C#方法。

    系列目录     【已更新最新开发文章,点击查看详细】
  • 相关阅读:
    Babyk勒索病毒数据集恢复,计算机服务器中了babyk勒索病毒怎么办?
    原油期货开户条件和流程是什么?
    【23种之外】设计模式介绍和简单工厂模式(静态工厂方法)
    如何快速调整SMT贴片编程中的特殊元件角度?
    vim、gcc/g++、make/Makefile、yum、gdb
    Elasticsearch:Data streams(二)
    Docker Compose:简化多容器管理的利器
    面向对象的编程语言是什么意思?——跟老吕学Python编程
    第4章 进程同步
    文件批量重命名:自定义命名与扩展名更改
  • 原文地址:https://www.cnblogs.com/SavionZhang/p/16219159.html
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号