Qt 集成miniblink浏览器库之3 C++ js相互调用

19 篇文章 0 订阅
本文介绍了如何在Qt中使用miniblink实现C++与JavaScript之间的通信。通过wkeRunJSW接口调用JavaScript函数,并展示了如何定义一个JavaScript回调函数,使JavaScript能够调用C++代码。示例中详细解释了函数绑定和参数传递的过程。
摘要由CSDN通过智能技术生成

上一节已经将miniblink集成到qt,实现了浏览器得基本调用接口,这一节介绍如何实现通信。

1.C++调用js

miniblink接口wkeRunJSW可以实现C++调用js

例如我们在js中写一个绑定到window的函数openDialog

就可以这样调用

wkeRunJSW("window.openDialog()");

这跟cef,QtWebEngine完全一样

 

2.js调用C++

首先我们写一个测试的html如下:

<html>

<head>
    <script>
            
            function onInvokeMethodClicked() {
                methodCallback("Recrod", "start", "param“);
            }
            
    </script>
</head>
<body οnlοad="onLoad()" id="main">
    <h1 align="center" style="font-size:12pt; font-family:MS Shell Dlg 2;">Web Area</h1>
    <div align="center" id="dragarea" style="height:40px; background-color: gray; color: white;" οnmοusedοwn="onDragAreaMouseDown()">
        <span style="font-size:18pt; font-family:MS Shell Dlg 2;">you can drag this window in this area!</span>
    </div>
    <div align="center">
      <label> Test Case for InvokeMethod </label>
      <br />
      <input type="button" value="Invoke Method" οnclick="onInvokeMethodClicked()" />
      <br />

    </div>
</body>

</html>

然后我们调用wkeJsBindFunction(functionName.toStdString().c_str(), fun, nullptr, paracount); 来绑定一个函数。在我的例子中为methodCallback。

所以这样调用

wkeJsBindFunction("methodCallback",  methodCallback, nullptr, 3);

第一个参数时函数名,也就是我们js中要调用的函数名称,第二个参数是回调函数,js调用会回到到此函数,第三个参数一般无用,第四个参数为绑定函数的参数个数。

回到函数格式为:

jsValue WKE_CALL_TYPE methodCallback(jsExecState es, void* param)
{
    if (0 == jsArgCount(es))
          return jsUndefined();
      jsValue arg0 = jsArg(es, 0);
      jsValue arg1 = jsArg(es, 1);
      if (!jsIsString(arg0))
          return jsUndefined();

      std::string mothod = jsToTempString(es, arg0);
      std::string parmar = jsToTempString(es, arg1);
      qDebug()<<"js-c++method:"<<QString::fromStdString(mothod);
      qDebug()<<"js-c++parmar:"<<QString::fromStdString(parmar);
    return jsUndefined();
}

在回到函数我们可以解析参数,获取调用的参数进而实现功能。

完毕

  • 1
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值