WinForm 嵌入 HTML 后怎样调用 JS 函数

2025-01-09 16:02:42   小编

WinForm 嵌入 HTML 后怎样调用 JS 函数

在 WinForm 开发中,将 HTML 嵌入其中能带来丰富的界面展示效果,而实现 WinForm 与嵌入 HTML 中的 JS 函数交互则进一步拓展了应用功能。那么,WinForm 嵌入 HTML 后究竟怎样调用 JS 函数呢?

要在 WinForm 中嵌入 HTML,通常会使用 WebBrowser 控件。通过将其拖放到 WinForm 界面上,并设置相关属性,就能加载本地 HTML 文件或网页。比如,在代码中使用 webBrowser1.Navigate("yourHTMLFile.html") 即可加载指定的 HTML 文件。

接下来就是关键的调用 JS 函数环节。一种常用的方法是利用 WebBrowser 控件的 InvokeScript 方法。假设在 HTML 文件中有一个名为 myFunction 的 JS 函数,在 WinForm 中要调用它,代码可以这样写:

if (webBrowser1.Document!= null)
{
    webBrowser1.Document.InvokeScript("myFunction", null);
}

这里的 InvokeScript 第一个参数是要调用的 JS 函数名,第二个参数是一个对象数组,用于向 JS 函数传递参数。若 myFunction 函数需要接收参数,例如 myFunction(int param),那么在 WinForm 中调用时可以这样:

if (webBrowser1.Document!= null)
{
    object[] args = { 10 };
    webBrowser1.Document.InvokeScript("myFunction", args);
}

还可以通过 ScriptObjectInjection 特性来实现调用。先在 WinForm 中定义一个类,类中的方法会作为 JS 可调用的对象。

public class MyJsObject
{
    public void CallFromJs()
    {
        // 执行相关逻辑
    }
}

然后在加载 HTML 前将这个对象注入到 WebBrowser 中:

MyJsObject myObject = new MyJsObject();
webBrowser1.ObjectForScripting = myObject;

在 HTML 的 JS 代码中就可以通过 window.external.CallFromJs() 来调用 WinForm 中的方法,实现双向交互。

掌握这些方法,开发者就能在 WinForm 嵌入 HTML 的项目中灵活地调用 JS 函数,实现更强大、更丰富的功能,为用户带来更好的交互体验,在软件开发过程中发挥出更大的价值。

TAGS: WinForm开发 WinForm嵌入HTML 调用JS函数 WinForm与JS交互

欢迎使用万千站长工具!

Welcome to www.zzTool.com