CefSharp 从现有 Javascript 函数中获取结果
CefSharp get result from existing Javascript function
我试图通过在 Windows 表单应用程序中使用 CefSharp,从本地 html 页面上现有的 Javascript 函数获取结果。
html 页面来源是:
<!DOCTYPE html>
<html>
<body>
<p id="demo">A Paragraph.</p>
<script>
function myFunction() {
document.getElementById("demo").innerHTML = true;
return 1 + 1;
}
</script>
</body>
</html>
我的 C# 代码是:
private void ChromeBrowser_LoadingStateChanged(object sender, LoadingStateChangedEventArgs args)
{
if (!args.IsLoading)
{
string result = RunScriptParamAsync("myFunction").ToString();
}
}
public string RunScriptParamAsync(string scriptName)
{
string script = "";
script = scriptName;
//script = string.Format("(function myFunction() {{ document.getElementById('demo').innerHTML = \"{0}\"; return 1 + 1; }})();", scriptName);
chromeBrowser.EvaluateScriptAsync(script).ContinueWith(x =>
{
var response = x.Result;
if (response.Success && response.Result != null)
{
dynamic result = response.Result;
return ((int)result).ToString();
}
else
{
return string.Empty;
}
});
return string.Empty;
}
如果我使用注释行
//script = string.Format("(function myFunction() {{ document.getElementById('demo').innerHTML = \"{0}\"; return 1 + 1; }})();", scriptName);
然后我得到了正确的结果 (2),但我的想法是使用网页上已经存在的 Javascript 函数。
函数内的断点揭示了这一点:
我也试过了
chromeBrowser.GetMainFrame().EvaluateScriptAsync(script)
但结果相同。
有什么想法吗?
您得到的正是您所要求的,对 function.You 的引用需要附加 ();
才能实际执行函数。
//Will return a IJavascriptCallback, which is effectively a function pointer, which is what you have asked for
await browser.EvaluateScriptAsync("myFunction");
//To execute the function you must append ();
await browser.EvaluateScriptAsync("myFunction();")
我试图通过在 Windows 表单应用程序中使用 CefSharp,从本地 html 页面上现有的 Javascript 函数获取结果。
html 页面来源是:
<!DOCTYPE html>
<html>
<body>
<p id="demo">A Paragraph.</p>
<script>
function myFunction() {
document.getElementById("demo").innerHTML = true;
return 1 + 1;
}
</script>
</body>
</html>
我的 C# 代码是:
private void ChromeBrowser_LoadingStateChanged(object sender, LoadingStateChangedEventArgs args)
{
if (!args.IsLoading)
{
string result = RunScriptParamAsync("myFunction").ToString();
}
}
public string RunScriptParamAsync(string scriptName)
{
string script = "";
script = scriptName;
//script = string.Format("(function myFunction() {{ document.getElementById('demo').innerHTML = \"{0}\"; return 1 + 1; }})();", scriptName);
chromeBrowser.EvaluateScriptAsync(script).ContinueWith(x =>
{
var response = x.Result;
if (response.Success && response.Result != null)
{
dynamic result = response.Result;
return ((int)result).ToString();
}
else
{
return string.Empty;
}
});
return string.Empty;
}
如果我使用注释行
//script = string.Format("(function myFunction() {{ document.getElementById('demo').innerHTML = \"{0}\"; return 1 + 1; }})();", scriptName);
然后我得到了正确的结果 (2),但我的想法是使用网页上已经存在的 Javascript 函数。
函数内的断点揭示了这一点:
我也试过了
chromeBrowser.GetMainFrame().EvaluateScriptAsync(script)
但结果相同。
有什么想法吗?
您得到的正是您所要求的,对 function.You 的引用需要附加 ();
才能实际执行函数。
//Will return a IJavascriptCallback, which is effectively a function pointer, which is what you have asked for
await browser.EvaluateScriptAsync("myFunction");
//To execute the function you must append ();
await browser.EvaluateScriptAsync("myFunction();")