繁体   English   中英

如何在 WebView Windows 10 UWP 中调用 javascript?

[英]How to invoke javascript in WebView Windows 10 UWP?

我正在尝试在 WebView 中加载一个 javascript 来进行一些计算并以字符串形式获取输出。 我尝试使用以下代码

string htmlFragment = "<html><head><script type='text/javascript'>" +
                    "function doubleIt(incoming){ " +
                    "  var intIncoming = parseInt(incoming, 10);" +
                    "  var doubled = intIncoming * 2;" +
                    "  document.body.style.fontSize= doubled.toString() + 'px';" +
                    "  return doubled.toString());" +
                    "};" +
                    "</script></head><body>" +
                    "<div id = 'myDiv'>I AM CONTENT</div></body></html>";
            htmlView.NavigateToString(htmlFragment);
            htmlView.LoadCompleted += async(s1,e1) =>
              {
                  string result = await htmlView.InvokeScriptAsync("eval", new string[] { "doubleIt(25)" });
                  Debug.WriteLine(result);
              };

更新我现在可以根据答案中提供的帮助轻松加载简单的 javascript。 但是现在当 javascript 中有多个函数时,我遇到了问题,我得到了一个例外。 我正在尝试以下代码

string htmlFragment = @"<html><head><script type='text/javascript'>" +
                    "function a(){return 10;};" +
                    "function b(){return 20;};" +
                    "function c(){return 30;};" +
                    "return (a()*b()*c());" +
                    "</script></head><body>" +
                    "<div id = 'myDiv'>I AM CONTENT</div></body></html>";

请建议。

此功能的文档非常糟糕。 我花了一些时间才弄清楚如何在 UWP WebView调用Javascript

当您第一次查看函数调用webView.InvokeScriptAsync(string,string[])您最初的反应是他们希望函数名称作为第一个参数,然后函数参数作为字符串数组。 (主要是因为 MSDN 文档是这么说的)

参数

脚本名称

类型:System.String [.NET] | 平台::字符串 [C++]

要调用的脚本函数的名称。

争论

类型:System.String[] [.NET] | 平台::数组 [C++]

将参数打包到脚本函数的字符串数组。

然而,这是错误的,会导致数小时的头部撞击。 真的,他们想要的是第一个参数中的“eval”这个词,然后是一个字符串数组,或者你想评估的命令

   var value = await webViewer.InvokeScriptAsync("eval", 
      new string[] 
      { 
        "functionName(functionParams)" 
      });

使用 Microsoft API 工作了几年,现在我确信这不是使用此函数的预期方式,而且有点小技巧。 不幸的是,如果你想使用 JavaScript,这是我知道目前唯一有效的方法。

Anthony,请尝试检查您自己的建议:

 await webViewer.InvokeScriptAsync("eval", 
  new string[] 
  { 
    "functionName(functionParams)" 
  });

或:

await webViewer.InvokeScriptAsync(functionName, new string[]{ functionParameters });

与 Microsoft 建议的相同,只是您将函数名称限制为 1(“eval”) - 没有必要。 相信我,您可以使用任何函数名称,就像我现在使用 UWP 和之前使用 Windows Phone 混合应用程序一样。

这个问题已经有 4 年了,但我来看看为什么你会得到一个空字符串。

在您的示例中,JavaScript 中的函数返回整数,而预期值是字符串类型。

通过修改这些函数并返回这样的字符串:

string htmlFragment = @"<html><head><script type='text/javascript'>" +
                    "function a(){return '10';};" +
                    "function b(){return '20';};" +
                    "function c(){return '30';};" +
                    "</script></head><body>" +
                    "<div id = 'myDiv'>I AM CONTENT</div></body></html>";

我们在回来的路上得到了好结果。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM