转自:

一、 简介 
Qt提供了本地C++对象与JavaScript的无缝集成,可以进行本地与web混合应用开发。利用Qt的Webkit集成与QtNetwork模块,可以自由的混合JavaScript、样式表、Web内容和Qt组件。对于C++和javaScript通信,最基本也最复杂的做法是使用COM,本文主要介绍使用Qt提供的QWebView和javaScript进行通信。 
二、 流程 
 基本函数介绍 
Qt与JavaScript互调是通过QWebFrame两个函数来实现的:addToJavaScriptWindowObject()将QObject对象传给JS,这样JS就能调用QObject的共有槽函数。Qt通过evaluateJavaScript()直接调用JS中德函数。其流程如下图: 

   函数说明
1. void QWebFrame::addToJavaScriptWindowObject(const QString& name,
QObject * object)
第一个参数:name为对象在javaScript里的名字,可以自由命名。
第二个参数:object对应的QObject实例指针。
要在JS调用该QObject之前调用这个函数,建议将这个函数放到一个signal的槽函数中调用,其使用代码代码如下:
connect(ui.webView->page()->mainFrame(),SIGNAL(javaScriptWindowObjectCleared()),this, SLOT(populateJavaScriptWindowObject()));
相应的槽函数为:
void 类名::populateJavaScriptWindowObject()
{
ui.webView->page()->mainFrame()->addToJavaScriptWindowObject(“formExtractor”, this);
}
2. QVariant QWebFrame::evaluateJavaScript(const QString &scriptSource)
建立一个工程,拖入一个QWebView,载入html网页,添加一个按钮调用javaScript,其代码为:
Ui.webView->page()->mainframe()->evaluateJavaScript(“Test()”) ;
其中Test()为javaScript中的Test()函数。
附注:如果Qt调用js函数,js函数带有参数,在Qt里该函数调用方法要写成如下形式:
QString method = QString(“JSFunction(\”%1\” , \”%2\”)”).arg(param1).arg(param2) ;
Ui.webView->page()->mainframe()->evaluateJavaScript(method) ; 三、 工程示例 新建Qt GUI工程项目QtJS,类名为mainWindow,继承基类选择为QMainWindow。往ui里拖入控件,其布局按如下设置:
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23

在mainwindow.cpp中添加头文件#include <QtCore/QUrl>、#include<QtWebK
itWidgets/QWebView>、#include <QtWebKitWidgets/QWebFrame>、#include<QtW
ebkit/QWebElement>。在mainwindow.h头文件中添加公有槽函数
void populateJavaScriptWindowObject() ;//为了保证每次打开新网页或刷新网页时都调用,将该槽函数和javaScriptWindowObjectCleared()信号相连
void pop1() ; //不传递参数到JavaScript
void pop2() ;//将Qt中的值传递到JavaScript
void JsCallQt() ;//JavaScript调用Qt,不传递参数
void JsCallQt(QStringList str) ;//JavaScript调用Qt,传递参数
在构造函数中建立信号和槽的连接
connect(ui.pushButton , SIGNAL(clicked()) , this , SLOT(pop1())) ;
connect(ui.pushButton_2 , SIGNAL(clicked()) , this , SLOT(pop2())) ;
connect(ui.webView->page()->mainFrame() , SIGNAL(javaScriptWindow
-ObjectCleared()) , this , SLOT(populateJavaScriptWindowObject())) ;
分别添加槽函数的定义:
void mainWindow::populateJavaScriptWindowObject()
{
ui.webView->page()->mainFrame()->addToJavaScriptWindowObject("A" , this) ;
}
单击按钮(“不带参数传递到JS”),其效果如下图:
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20

弹出对话框为html中的一个警告,其代码如下: 
在文本框中输入X、Y的值,单击按钮(“带参数传递到JS”),其效果

 
通过JavaScript调用Qt主要有两种方式,第一种:在Qt中定义一个公有的槽函数;第二种:在公有成员函数前添加Q_INVOKABLE宏。 
添加JsCallQt()的定义如下:

void mainWindow::JsCallQt(QStringList str)
{
ui.lineEdit_3->setText(str[0]) ;
ui.lineEdit_4->setText(str[1]) ;
}
void mainWindow::JsCallQt()
{
QWebFrame *frame = ui.webView->page()->mainFrame();
QWebElement X = frame->findFirstElement("#X");
ui.lineEdit_3->setText(X.evaluateJavaScript("this.value").toString()) ;
QWebElement Y = frame->findFirstElement("#Y");
ui.lineEdit_4->setText(Y.evaluateJavaScript("this.value").toString()) ;
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15

JsCallQt()的两个版本分别对应html中的两个按钮,推荐使用第二种方式。第一种带参数传递时,好像需要在javascript中将变量设置为数组,传递多个参数时好像会失效(有兴趣可以验证)。 
单击html中的按钮(“第二种方式传递到Qt”),其显示效果如下图: 

一、 简介 
Qt提供了本地C++对象与JavaScript的无缝集成,可以进行本地与web混合应用开发。利用Qt的Webkit集成与QtNetwork模块,可以自由的混合JavaScript、样式表、Web内容和Qt组件。对于C++和javaScript通信,最基本也最复杂的做法是使用COM,本文主要介绍使用Qt提供的QWebView和javaScript进行通信。 
二、 流程 
 基本函数介绍 
Qt与JavaScript互调是通过QWebFrame两个函数来实现的:addToJavaScriptWindowObject()将QObject对象传给JS,这样JS就能调用QObject的共有槽函数。Qt通过evaluateJavaScript()直接调用JS中德函数。其流程如下图: 

   函数说明
1. void QWebFrame::addToJavaScriptWindowObject(const QString& name,
QObject * object)
第一个参数:name为对象在javaScript里的名字,可以自由命名。
第二个参数:object对应的QObject实例指针。
要在JS调用该QObject之前调用这个函数,建议将这个函数放到一个signal的槽函数中调用,其使用代码代码如下:
connect(ui.webView->page()->mainFrame(),SIGNAL(javaScriptWindowObjectCleared()),this, SLOT(populateJavaScriptWindowObject()));
相应的槽函数为:
void 类名::populateJavaScriptWindowObject()
{
ui.webView->page()->mainFrame()->addToJavaScriptWindowObject(“formExtractor”, this);
}
2. QVariant QWebFrame::evaluateJavaScript(const QString &scriptSource)
建立一个工程,拖入一个QWebView,载入html网页,添加一个按钮调用javaScript,其代码为:
Ui.webView->page()->mainframe()->evaluateJavaScript(“Test()”) ;
其中Test()为javaScript中的Test()函数。
附注:如果Qt调用js函数,js函数带有参数,在Qt里该函数调用方法要写成如下形式:
QString method = QString(“JSFunction(\”%1\” , \”%2\”)”).arg(param1).arg(param2) ;
Ui.webView->page()->mainframe()->evaluateJavaScript(method) ; 三、 工程示例 新建Qt GUI工程项目QtJS,类名为mainWindow,继承基类选择为QMainWindow。往ui里拖入控件,其布局按如下设置:
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23

在mainwindow.cpp中添加头文件#include <QtCore/QUrl>、#include<QtWebK
itWidgets/QWebView>、#include <QtWebKitWidgets/QWebFrame>、#include<QtW
ebkit/QWebElement>。在mainwindow.h头文件中添加公有槽函数
void populateJavaScriptWindowObject() ;//为了保证每次打开新网页或刷新网页时都调用,将该槽函数和javaScriptWindowObjectCleared()信号相连
void pop1() ; //不传递参数到JavaScript
void pop2() ;//将Qt中的值传递到JavaScript
void JsCallQt() ;//JavaScript调用Qt,不传递参数
void JsCallQt(QStringList str) ;//JavaScript调用Qt,传递参数
在构造函数中建立信号和槽的连接
connect(ui.pushButton , SIGNAL(clicked()) , this , SLOT(pop1())) ;
connect(ui.pushButton_2 , SIGNAL(clicked()) , this , SLOT(pop2())) ;
connect(ui.webView->page()->mainFrame() , SIGNAL(javaScriptWindow
-ObjectCleared()) , this , SLOT(populateJavaScriptWindowObject())) ;
分别添加槽函数的定义:
void mainWindow::populateJavaScriptWindowObject()
{
ui.webView->page()->mainFrame()->addToJavaScriptWindowObject("A" , this) ;
}
单击按钮(“不带参数传递到JS”),其效果如下图:
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20

弹出对话框为html中的一个警告,其代码如下: 
在文本框中输入X、Y的值,单击按钮(“带参数传递到JS”),其效果

 
通过JavaScript调用Qt主要有两种方式,第一种:在Qt中定义一个公有的槽函数;第二种:在公有成员函数前添加Q_INVOKABLE宏。 
添加JsCallQt()的定义如下:

void mainWindow::JsCallQt(QStringList str)
{
ui.lineEdit_3->setText(str[0]) ;
ui.lineEdit_4->setText(str[1]) ;
}
void mainWindow::JsCallQt()
{
QWebFrame *frame = ui.webView->page()->mainFrame();
QWebElement X = frame->findFirstElement("#X");
ui.lineEdit_3->setText(X.evaluateJavaScript("this.value").toString()) ;
QWebElement Y = frame->findFirstElement("#Y");
ui.lineEdit_4->setText(Y.evaluateJavaScript("this.value").toString()) ;
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15

JsCallQt()的两个版本分别对应html中的两个按钮,推荐使用第二种方式。第一种带参数传递时,好像需要在javascript中将变量设置为数组,传递多个参数时好像会失效(有兴趣可以验证)。 
单击html中的按钮(“第二种方式传递到Qt”),其显示效果如下图: 

Qt调用JS的更多相关文章

  1. Qt调用JS(二)

    转自:http://www.cnblogs.com/verstin/p/4908673.html <html> <script language="JavaScript&q ...

  2. qt调用js,js调用qt

    <html> <script language="JavaScript"> function qtcalljs() { alert("sdfsd& ...

  3. Qt与JS(三)

    Qt不错的学习网址: http://www.cnblogs.com/findumars/p/5529526.html ----------------------------------------- ...

  4. 【问题】Asp.net MVC 的cshtml页面中调用JS方法传递字符串变量参数

    [问题]Asp.net MVC 的cshtml页面中调用JS方法传递字符串变量参数. [解决]直接对变量加引号,如: <button onclick="deleteProduct('@ ...

  5. iOS开发--OC调用JS篇

    OC调用JS篇 其中相对应的html部分如下: <html> <header> <meta http-equiv="Content-Type" con ...

  6. js调用php和php调用js的方法举例

    js调用php和php调用js的方法举例1 JS方式调用PHP文件并取得php中的值 举一个简单的例子来说明: 如在页面a.html中用下面这句调用: <script type="te ...

  7. ActiveX(三)ActiveX 调用 Js

    在上一篇随笔: ActiveX(二)Js 监听 ActiveX中的事件  中,已经可以实现 Js 监听 ActiveX中的事件,至此.Js 和 ActiveX 已经可以实现双向通讯了.但是.这样的实现 ...

  8. 配合 APP 调用 JS 的一次尝试

    项目初衷 最初的场景是用户在对购物车的操作中,由于用户对购物车的每次操作(包括选择,调整数量)都需要计算商品的促销和分组的情况,而这段逻辑的计算都需要调用后端的接口,那么瓶颈来了: 请求时间长--一次 ...

  9. QT 调用VS2015编写的Dll

    最近在用QT调用VC生成的库,QT使用的是MinGW调试器,出现与动态库不兼容的问题,最后发现QT只能识别VC生成的C格式下的动态库 也就是在导入导出设置时加入extern "C" ...

随机推荐

  1. 小米MAX开发者选项 以及如何连接MAC开发RN

    打开开发者选项:设置--我的设备---全部参数-- 多次点击MiUI版本 打开开发者选项 然后返回到设置的主页面里面的更多设置就可以看到开发者选项了 在开发者选项中打开 USB调试/USB安装 将启动 ...

  2. Spring的一个入门例子

    例子参考于:Spring系列教材 以及<轻量级JavaEE企业应用实战> Axe.class package com.how2java.bean; public class Axe { p ...

  3. JAVA实操项目:转账接口设计

    在一个项目中,一般都会支付相关的业务,而涉及到支付必定会有转账的操作,转账这一步想起来算是比较关键的部分,这个接口的设计能力,也大致体现出一个人的水平. 昨天碰到了一个题目: 尝试用java编写一个转 ...

  4. java基础题集

    1.什么是java虚拟机?为什么java被称作是“平台无关的编程语言”? java虚拟机是一个可以执行java字节码的虚拟机进程.java源文件被编译成能被java虚拟机执行的字节码文件. java被 ...

  5. iOS获取UUID

    转自:<iOS获取设备的唯一标识的方法总结以及最好的方法> 参考:<获取iOS设备唯一标识> 总结一下: 1.代码采用CFUUID+KeyChain的实现方式. 2.CFUUI ...

  6. 牛客小白月赛7 CSL的校园卡

    CSL的校园卡 思路: bfs,用状压表示走过的区域,然后和x1,y1,x2,y2构成所有的状态,然后标记一下就可以了 代码: #pragma GCC optimize(2) #pragma GCC ...

  7. webpack踩坑之路 (2)——图片的路径与打包

    刚开始用webpack的同学很容易掉进图片打包这个坑里,比如打包出来的图片地址不对或者有的图片并不能打包进我们的目标文件夹里(bundle).下面我们就来分析下在webpack项目中图片的应用场景. ...

  8. ubuntu 16.04 下安装smplayer视频播放器

    安装平台:ubuntu 16.04 1.sudo apt-add-repository ppa:rvm/smplayer 2.sudo apt-get update 3.sudo apt-get in ...

  9. 父子元素select悬浮代码,兼容火狐

    //公共切换方法 function SwitchCommon() { //悬浮显示 $(document.body).on("mouseenter", "[hex-eid ...

  10. hadoop 企业应用案例--大众点评

    hadoop 企业应用案例--大众点评 http://f.dataguru.cn/thread-260531-1-1.html