ScriptGate是一个实现TWebBrowser上的JavaScript和Delphi代码相互调用的库

ScriptGate是一个实现TWebBrowser上的JavaScript和Delphi代码相互调用的库,具体在这里:https://bitbucket.org/freeonterminate/scriptgate

用ScriptGate,我们可以轻松实现JavaScript在Delphi上的使用了,目前支持最新的Delphi tokyo 10.2.3版,注意,属于FMX类型的控件,作者说支持Windows,MacOS,Android及iOS.

我该怎么办?


例如,您可以从Delphi调用以下JavaScript方法。

<head> 
  <script type = “text / javascript” > 
    function  helloJS ()
    { 
      alert (“Hello,JavaScript!” ); 
    } 
  </ script> 
</ head>
procedure TForm1.Button1Click(Sender: TObject);
begin
  FScriptGate.CallScript(‘helloJS()‘);
end;

看清了吧,在Delphi中调用JavaScript的helloJS。

反之,再看看从JavaScript调用Delphi方法:

procedure TForm1.HelloDelphi()
begin
  ShowMessage(‘Hello, Delphi!‘);
end;
<body>
  <a href="delphi:HelloDelphi()">Call Delphi</a>
</body>

注意这里的“delphi:”字符串,是TScriptGate构造函数指定的方案,不明白,那继续往下看。

尝试使用ScriptGate


 

准备工作


 

首先,从BitBucket下载代码。

接下来,在新建中的“多设备应用程序”中选择“空应用程序”。
*当然可以将其合并到现有项目中,但仅限于FireMonkey应用项目。
将下载并解压的代码目录添加到搜索路径。

如果Android包含在开发目标中,请将SGWebClient.jar添加到Android的库中。

至此,准备工作完成。

建立TScriptGate


 

这里我们将ScriptGate与WebBrowser1,TForm1结合使用。

unit Unit1;

interface

uses
  {...}
  SG.ScriptGate; //手工引用此单元

type
  TForm1 = class(TForm)
    WebBrowser1: TWebBrowser;
    Layout1: TLayout;
    Button1: TButton;
    procedure FormCreate(Sender: TObject);
    procedure Button1Click(Sender: TObject);
  private var
    FScriptGate: TScriptGate; // 增加一个FScriptGate对象
  public
    procedure HelloDelphi; // 增加一个准备在JS中调用的Delphi方法
  end;

 利用Form1的OnCreate事件,先建一个TScriptGate的实例对象FScriptGate

implementation

procedure TForm1.FormCreate(Sender: TObject);
begin
  FScriptGate := TScriptGate.Create(Self, WebBrowser1, ‘delphi‘);
end;

TScriptGate.Create原型:

constructor Create(
  const iReceiver: TObject;
  const iWebBrowser: TWebBrowser;
  const iScheme: String); reintroduce;
  • iReceiver

iReceiver是一个从JavaScript接收响应的实例。
这里TForm1被指定,但它可以是类的任何实例。
这里指定的实例的方法可以被JavaScript调用。

如:

type
  TReceiver = class
  public
    procedure Foo;
    procedure Bar(const msg: String);
  end;

如果您指定名为TReceiver 的类的实例,则可以从JavaScript调用Bar方法。
这里需要注意的是,暴露给JavaScript的方法的访问级别必须是Public的或更高级别的。
它使用RTTI进行方法查找。

  • iWebBrowser

指定TScriptGate所关联的TWebBrowser的一个实例。
您可以调用指定WebBrowser加载的JavaScript方法。

  • IScheme

调用第一个示例中附加的iScheme ScriptGate方法“delphi:”的参数。
这与指定本地文件时使用JavaScript或“file:”时指定的“JavaScript:”具有相同的含义。
无论你在这里指定什么,你还必须在JavaScript端指定相同的字符串。
请注意,传递给参数的字符串不需要冒号“:”。

然后编写一个调用JavaScript的方法和一个从JavaScript调用的方法。

//在JavaScript中调用helloJS()。
//你也可以使用匿名函数检索返回值。
procedure TForm1.Button1Click(Sender: TObject);
begin
  FScriptGate.CallScript(
    ‘helloJS()‘,
    procedure(const iResult: String)
    begin
      ShowMessage(iResult);
    end
  );
end;
//允许JavaScript调用的方法,JavaScript中的方法被称为HelloDelphi。
procedure TForm1.HelloDelphi;
begin
  ShowMessage(‘Hello, Delphi!‘);
end;
 

  加载到WebBrowser1中的HTML如下所示。

<html> 
  <header> 
    <script type="text/JavaScript"> 
      function helloJS() { alert("Hello, JavaScript!"); return "Hello !!"; }
    </script> 
  </head> 

  <body> 
    <br><br> 
    <a href="delphi:HelloDelphi()">Call Delphi procedure</a> 
  <body> 
</html>;

 下面是作者写的完整的例子,演示了Delphi与JavaScript间如何互相调用以及在调用时,如何传递参数。

unit Unit1;

interface

uses
  System.SysUtils, System.Types, System.UITypes, System.Classes, System.Variants,
  FMX.Types, FMX.Controls, FMX.Forms, FMX.Graphics, FMX.Dialogs,
  FMX.Controls.Presentation, FMX.StdCtrls, FMX.Layouts, FMX.WebBrowser,
  SG.ScriptGate;

type
  TForm1 = class(TForm)
    WebBrowser1: TWebBrowser;
    Layout1: TLayout;
    Button1: TButton;
    Layout2: TLayout;
    Button2: TButton;
    procedure FormCreate(Sender: TObject);
    procedure Button1Click(Sender: TObject);
    procedure Button2Click(Sender: TObject);
  private var
    FScriptGate: TScriptGate;
  public
    procedure HelloDelphi(const iStr: String);
    procedure Add(const Msg: String; const A, B: Integer);
  end;

var
  Form1: TForm1;

implementation

{$R *.fmx}

const
  SampleHTML =
    ‘<html>‘ +
    ‘<header>‘ +
      ‘<script type="text/JavaScript">‘ +
        ‘function helloJS(msg, msg2) { alert(msg + msg2); return "Hello Delphi ! I am JavaScript !"; }‘ + // Call from Delphi
      ‘</script>‘ +
    ‘</head>‘ +
    ‘<body>‘ +
      ‘<br><br>‘ + // Call Delphi Method
      ‘<a href="YourOrgScheme:HelloDelphi(‘‘call by JS‘‘)">Call Delphi noparam procedure</a>‘ +
      ‘<br><br>‘ +
      ‘<a href="YourOrgScheme:Add(‘‘Calc: 30 + 12 = ‘‘, 30, 12)">Call Delphi procedure</a>‘ +
    ‘<body>‘ +
    ‘</html>‘;

procedure TForm1.FormCreate(Sender: TObject);
begin
  WebBrowser1.LoadFromStrings(SampleHTML, ‘/‘);

  // The method of the object specified by the first argument is
  // called from JavaScript.
  FScriptGate := TScriptGate.Create(Self, WebBrowser1, ‘YourOrgScheme‘);
end;

procedure TForm1.Button1Click(Sender: TObject);
begin
  FScriptGate.CallScript(
    ‘helloJS("Hello JS ! ", "I am Delphi !")‘,
    procedure(const iResult: String)
    begin
      ShowMessage(iResult);
    end
  );
end;

procedure TForm1.Button2Click(Sender: TObject);
begin
  FScriptGate.Eval(
    ‘document.getElementsByTagName("html")[0].outerHTML‘,
    procedure(const iResult: String)
    begin
      ShowMessage(iResult);
    end
  );
end;

procedure TForm1.Add(const Msg: String; const A, B: Integer);
begin
  ShowMessage(Msg + (A + B).ToString);
end;

procedure TForm1.HelloDelphi(const iStr: String);
begin
  ShowMessage(‘Hello ! ‘ + iStr);
end;

end.

 

开源项目ScriptGate,Delphi与JavaScript相互调用的神器

标签:pes   响应   mst   控件   访问   指定   use   nta   下载   

原文地址:https://www.cnblogs.com/kinglandsoft/p/9249374.html

Delphi中,要在Android应用中利用TWebBrowser组件实现字符串查找定位功能,可以借助其内置的Web浏览器控件以及JavaScript API。首先,你需要确保你的项目集成了支持HTML和JavaScript的组件。 以下是简单的步骤: 1. **设置环境**: 确保你的Delphi项目已经配置为支持Android开发,并集成到Embarcadero FireMonkey(FMX)框架中,这是Delphi用于跨平台UI开发的。 2. **使用TWebBrowser控件**: 在Android Form上添加一个TWebBrowser控件,例如`TBrowsers`。 ```delphi uses FMX.Web.Browser; procedure TForm1.Button1Click(Sender: TObject); begin TBrowsers.Navigate('http://example.com'); // 加载网页 end; ``` 3. **JavaScript交互**: JavaScript允许通过`window.location.search`获取URL查询参数,你可以动态构造一个函数,监听某个字符串,然后在页面内容中查找匹配项。 ```delphi procedure TForm1.TBrowsers.OnMessage(Message: TWebBrowserMessage; var WParam, LParam: Pointer); inline; begin if Message = wbmOnLocationChange then begin WebBrowser1.Document.ExecuteScript( 'function findString(strToFind) { var matches = document.body.innerText.match(new RegExp(strToFind, "gi")); if (matches != null) { for (var i = 0; i < matches.length; i++) { alert(matches[i]); } } else { alert("String not found."); } }', nil); end; end; ``` 在这个例子中,当URL改变(比如用户点击前进或后退按钮),会调用`findString`函数,查找指定的字符串并显示结果(使用JavaScript的`alert`函数)。 4. **触发查找**: 当需要查找特定字符串时,可以在按钮点击事件或者其他适当的地方调用这个函数,传入要搜索的字符串作为参数。 ```delphi procedure TForm1.Button2Click(Sender: TObject); begin TBrowsers.ExecuteScript('findString("' + SearchTerm + '")'); end; ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值