TEdgeBrowser 组件:从嵌入式网页上的脚本 运行 调用本机代码
TEdgeBrowser component: calling native code from a script running on the embedded web page
目前我们使用 TWebBrowser
组件将 IE 嵌入到我们的桌面应用程序中。为了在嵌入式浏览器中从脚本 运行 调用 Delphi 代码,我们实现了对 window.external
对象的支持,如下所述:http://www.delphidabbler.com/articles/article-22
现在,出于多种原因,我们需要切换到现代浏览器。我们已经升级到 Delphi 10.4,它引入了新的 TEdgeBrowser
组件(基于 Chromium 的 MS Edge)。是否可以将 window.external
也用于 TEdgeBrowser
?如果是这样,如何?或者还有其他方法如何从嵌入式浏览器中的脚本调用本机代码?
终于很简单了。感谢 TOndrej 提供的“入门指南”link,它帮助我解决了这个问题。我还意识到它适用于 MS Edge Beta (84.0.522.28),因此不需要 Canary,如 Marco Cantu 在此处所述:https://blog.marcocantu.com/blog/2020-may-edge-browser-component.html。我希望它能尽快与官方 MS Edge 一起使用。以下是一些代码片段:
Delphi:
procedure TForm1.Button1Click(Sender: TObject);
begin
EdgeBrowser1.Navigate(ExtractFilePath(ParamStr(0)) + 'index.html');
end;
procedure TForm1.EdgeBrowser1WebMessageReceived(Sender: TCustomEdgeBrowser; Args: TWebMessageReceivedEventArgs);
var
Msg: PChar;
begin
Args.ArgsInterface.Get_webMessageAsJson(Msg);
MessageBox(Handle, Msg, PChar(EmptyStr), MB_OK);
end;
HTML:
<!DOCTYPE html>
<html>
<body>
<p onclick="handleClick()">Click me</p>
<script>
function handleClick() {
window.chrome.webview.postMessage({ data: 'Message from Edge Chromium', url: window.document.URL });
}
</script>
</body>
</html>
目前我们使用 TWebBrowser
组件将 IE 嵌入到我们的桌面应用程序中。为了在嵌入式浏览器中从脚本 运行 调用 Delphi 代码,我们实现了对 window.external
对象的支持,如下所述:http://www.delphidabbler.com/articles/article-22
现在,出于多种原因,我们需要切换到现代浏览器。我们已经升级到 Delphi 10.4,它引入了新的 TEdgeBrowser
组件(基于 Chromium 的 MS Edge)。是否可以将 window.external
也用于 TEdgeBrowser
?如果是这样,如何?或者还有其他方法如何从嵌入式浏览器中的脚本调用本机代码?
终于很简单了。感谢 TOndrej 提供的“入门指南”link,它帮助我解决了这个问题。我还意识到它适用于 MS Edge Beta (84.0.522.28),因此不需要 Canary,如 Marco Cantu 在此处所述:https://blog.marcocantu.com/blog/2020-may-edge-browser-component.html。我希望它能尽快与官方 MS Edge 一起使用。以下是一些代码片段:
Delphi:
procedure TForm1.Button1Click(Sender: TObject);
begin
EdgeBrowser1.Navigate(ExtractFilePath(ParamStr(0)) + 'index.html');
end;
procedure TForm1.EdgeBrowser1WebMessageReceived(Sender: TCustomEdgeBrowser; Args: TWebMessageReceivedEventArgs);
var
Msg: PChar;
begin
Args.ArgsInterface.Get_webMessageAsJson(Msg);
MessageBox(Handle, Msg, PChar(EmptyStr), MB_OK);
end;
HTML:
<!DOCTYPE html>
<html>
<body>
<p onclick="handleClick()">Click me</p>
<script>
function handleClick() {
window.chrome.webview.postMessage({ data: 'Message from Edge Chromium', url: window.document.URL });
}
</script>
</body>
</html>