• 【Delphi】使用TWebBrowser执行JavaScript命令传入JSON参数执行出错解决方案


    目录

    一、问题背景:

    二、实际示例:

    三、解决方案:

    1. Delphi 代码:

    2. javaScript代码:


    一、问题背景:

            在用Delphi开发程序,无论是移动端还是PC端,都可以很方便的使用TWebBrowser控件,从而使用H5,这样就可以实现非常完美的界面(谁用谁知道)。Delphi只负责提供一个程序框架(基座),整个UI界面通过TWebBrowser使用H5来实现,这样就可以产生各式各样的UI,而不在使用原生Delphi的UI控件,因为原生Delphi的UI控件在PC端的VCL还是很好用的,但是到了移动端,那就实在是不好用了。

            这样就势必会有个需求就是Delphi直接执行TWebBrowser中的javaScript函数命令,幸运的是TWebBrowser提供了这样的功能,这就是TWebBrowser的EvaluateJavaScript函数。

    1. //Delphi
    2. procedure EvaluateJavaScript(const JavaScript: string);

    参数 JavaScript 可以是定义 JavaScript 语句,也可以是当前页面已经存在的函数。如果是当前页面已经存在的函数,而且该函数还有一个JSON字符串参数,那么直接调用EvaluateJavaScript函数将会出现错误。

    二、实际示例:

    假如当前网页中有一个javaScript函数:

    1. //Delphi 底座调用的函数
    2. function OnDelphiCall(JSONStr) {
    3. let jo = JSON.parse(decodedData1);
    4. ElMessageBox.alert(jo.Server_Message_Content, jo.Server_Message_Title, {
    5. // if you want to disable its autofocus
    6. // autofocus: false,
    7. confirmButtonText: 'OK',
    8. showClose: false,
    9. })

    以上函数Delphi调用时需要传递一个JSON字符串,以便javaScript函数显示一个模式对话框(element-ui)

    1. {
    2. "Server_Message_Title":"提示",
    3. "Server_Message_Content":"数据保存成功!"
    4. }

    vue3中,实现Delphi 调用javaScript函数:

    onMounted(() => {

        //最新的统一 DelphiCall 函数

        window.DelphiCall = OnDelphiCall;

    })

    Delphi中实际调用函数:

    G_WebBrowser.EvaluateJavaScript('DelphiCall("' + JSONStr + '");');

    此时,如果直接将以下字符串赋值给 JSONStr,然后Delphi调用,肯定会出现错误。

            {
                "Server_Message_Title":"提示",
                "Server_Message_Content":"数据保存成功!"
            }

            因为以上字符串中包含{dakkuohao ,双引号等,将会导致javaScript执行错误(将参数当作命令,解析失败错误)

    三、解决方案:

            就是将字JSONStr字符串进行特殊的Base64处理,然后传递给javaScript,javaScript接收到参数后进行Base64解码后使用参数。

    1. Delphi 代码:

    1. uses
    2. System.NetEncoding;
    3. procedure ExecuteJavascript(Command,ParamsStr: string);
    4. var
    5. S : string;
    6. JSONStr64 : string;
    7. JavaScriptFunction : string;
    8. begin
    9. S := TNetEncoding.URL.Encode(ParamsStr,[],[]); //这里取消将空格作为+号处理
    10. JSONStr64 := TNetencoding.Base64.Encode(S);
    11. // Berlin 版本的会自动增加 回车换行,所以需要替换掉,高版本的不需要
    12. JSONStr64 := JSONStr64.Replace(#10,'');
    13. JSONStr64 := JSONStr64.Replace(#13,'');
    14. //2. 构造javascript 函数
    15. JavaScriptFunction := Command + '("' + JSONStr64 + '");'; // 'DelphiCall("' + JSONStr64 + '");';
    16. //3. 执行浏览器javascript函数
    17. G_WebBrowser.EvaluateJavaScript(JavaScriptFunction);
    18. end;

    2. javaScript代码:

    1. //Delphi 底座调用的函数
    2. function OnDelphiCall(JSONStr) {
    3. //进行Base64解密
    4. let decodedData = window.atob(JSONStr);
    5. let decodedData1 = decodeURIComponent(decodedData);
    6. let jo = JSON.parse(decodedData1);
    7. ElMessageBox.alert(jo.Server_Message_Content, jo.Server_Message_Title, {
    8. // if you want to disable its autofocus
    9. // autofocus: false,
    10. confirmButtonText: 'OK',
    11. showClose: false,
    12. })
    13. onMounted(() => {
    14. //最新的统一 DelphiCall 函数
    15. window.DelphiCall = OnDelphiCall;
    16. })

    如果没有用过TWebBrowser可能无法看懂本文!开发中实际遇到的问题,期望能够帮助到需要的人!

  • 相关阅读:
    ClickHouse Projection
    前端研习录(29)——JavaScript CSS操作讲解及示例分析
    深度学习遇到 DolphinDB AI DataLoader
    元宇宙的八大典型应用场景
    Water 2.6.1 发布,一站式服务治理平台
    网络安全学习--网络安全防护
    《Python 自动化办公应用大全》书籍推荐(包邮送书五本)
    入行IC | 从小白助理级,到总监专家级,到底要经历怎样的成长阶段呢?
    VS Code使用node.js编译,代码自动补全方法
    Kafka的消费流程
  • 原文地址:https://blog.csdn.net/sensor_WU/article/details/134563364