转自:

http://blog.163.com/qimo601@126/blog/static/15822093201682185819623/

Qt 4.8.4

感谢原作者,我只转载。
看看作者如何实现:
1、Qt源码调用html中js的函数disp_messagebox();
2、js源码中如何调用qt中的函数  
MainWindow.jsInvokeQt();
MainWindow.setInfor("Qt change string"); 
alert(MainWindow.getInfor());
 
页面载入完成的信号:
connect(ui.webView->page()->mainFrame(), SIGNAL(loadFinished(bool)),
           
this, SLOT(callFunction()));
 
由于篇幅限制,我就不发头文件了,详细源码可以下载附件QtInvokeJS.zip
#include "mainwindow.h"
#include "ui_mainwindow.h"


MainWindow::MainWindow(QWidget *parent) :
    QMainWindow(parent),
    ui(new Ui::MainWindow)
{
    ui->setupUi(this);

    /* 载入html网页 */
    m_pWebView = new QWebView();

    m_pWebView->load(QUrl("file:///D:/jsTest.html"));

    m_pWebView->show();

    /* 开启JavaScript支持 */
    QWebSettings *pWebSettings = m_pWebView->page()->settings();

    pWebSettings->setAttribute(QWebSettings::JavascriptEnabled,true);

    /* 窗体布局, 添加按钮 */
    QPushButton *pEventBtn = new QPushButton(tr("QT Invoke JavaScript web page Object"));
    QPushButton *pcloseBtn = new QPushButton(tr("close"));

    /* 布局:网页与按钮为上下布局,两按钮为水平居中布局 */
    QHBoxLayout *pBtnLayout = new QHBoxLayout;

    pBtnLayout->addWidget(pEventBtn);

    pBtnLayout->addWidget(pcloseBtn);

    pBtnLayout->setAlignment(Qt::AlignCenter);

    QVBoxLayout *pMainLayout = new QVBoxLayout;

    pMainLayout->addWidget(m_pWebView);

    pMainLayout->addLayout(pBtnLayout);

    QWidget *widget = new QWidget;

    widget->setLayout(pMainLayout);

    setCentralWidget(widget);

    /* 建立信号与槽, 每次载入html时发送段信号 */
    connect(m_pWebView->page()->mainFrame(),SIGNAL(javaScriptWindowObjectCleared()),
            this,SLOT(addObjectToJs()));

    connect(pEventBtn,SIGNAL(clicked()),this,SLOT(testJs()));

    connect(pcloseBtn,SIGNAL(clicked()),this,SLOT(close()));

    testStr.clear();
}

MainWindow::~MainWindow()
{
    if(m_pWebView != NULL)
    {
        delete m_pWebView;
        m_pWebView = NULL;
    }

    /* 必须的,否则,在debug编译模式下就会出现leak错误 */
    QWebSettings::globalSettings()->clearMemoryCaches();

    delete ui;
}

/* 这个public slot槽函数是为了响应JavaScript的的invoke的 */
void MainWindow::jsInvokeQt()
{
    qDebug()<<"MainWindow::jsInvokeQt(),\t JavaScript invoke Qt program!";
}

/* 将MainWindows这个类的名称&&对象指针发送给JavaScript */
void MainWindow::addObjectToJs()
{
    m_pWebView->page()->mainFrame()->addToJavaScriptWindowObject("MainWindow",this);
}

/* Qt来 invoke JavaScript里面的disp_messagebox()函数 */
void MainWindow::testJs()
{
    qDebug()<<"MainWindow::testJs(),\t Qt invoke JavaScript's function";
    m_pWebView->page()->mainFrame()->evaluateJavaScript("disp_messagebox()");
}

/* JavaScript invoke Qt里面的public slot 槽函数 */
void MainWindow::setInfor(const QString str)
{
    qDebug()<<"MainWindow::setInfor(const QString str),\t Response of js Invoke!"<<"var is:"<<str;
    if(str.isEmpty())
    {
        qDebug()<<"str is empty!";
        return;
    }
    else
    {
        testStr = str;
    }
}

/* JavaScript invoke Qt里面的public slot 槽函数 */
QString MainWindow::getInfor()
{
    qDebug()<<"MainWindow::GetInfor(),\t "<<testStr;
    return testStr;
}
-----------------------------------------------------------------------------
<html>
 
<head>
 
<script type="text/javascript">
 
function disp_messagebox()
{
    alert("This is javaScript MessageBox come from alert!")
 
function disp_qtmessage()
{
  alert("disp_messagebox function, who is in JavaScript!")
   
  MainWindow.jsInvokeQt();
 
  MainWindow.setInfor("Qt change string"); 
  
  alert(MainWindow.getInfor());
 
</script>
 
</head>
 
<body> 
 
<input type="button" onclick="disp_qtmessage()" value="JavaScript Invoke Qt Object" /> 
 
</body>
 
</html>

QT和JS的互相调用例子的更多相关文章

  1. node源码详解(四) —— js代码如何调用C++的函数

    本作品采用知识共享署名 4.0 国际许可协议进行许可.转载保留声明头部与原文链接https://luzeshu.com/blog/nodesource4 本博客同步在https://cnodejs.o ...

  2. Qt与JS(三)

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

  3. Atitit java c# php c++ js跨语言调用matlab实现边缘检测等功能attilax总结

    Atitit java c# php c++ js跨语言调用matlab实现边缘检测等功能attilax总结 1.1. 边缘检测的基本方法Canny最常用了1 1.2. 编写matlab边缘检测代码, ...

  4. Unity3D中C#和js方法相互调用

    通过查找资料,Unity3D中C#和js要相互调用彼此的方法,js文件必须放在"Standard Assets". "Pro Standard Assets" ...

  5. js函数的调用问题

    1.js函数的调用方式有三种.请问以下“二”处的几行代码有什么猫腻? //一 事件调用 btn.onclick=fn; //二 直接调用(window调用) fn(); //自上而下解析到这一行的时候 ...

  6. iOS js oc相互调用(JavaScriptCore)(二)

    下来我们使用js调用iOS js调用iOS分两种情况 一,js里面直接调用方法 二,js里面通过对象调用方法 首先我们看第一种,直接调用方法. 其中用到了iOS的block 上代码 -(void)we ...

  7. js switch表达式的例子

    switch 这种表达式在很多语言中都有,比如java, C等待, 使用switch比使用if else 来得方便,来得清晰.  前言 switch 这种表达式在很多语言中都有,比如java, C等待 ...

  8. gwt中java与js的相互调用

    1. java通过jsni调用内部js Button button = new Button("java调用内部jsni的js方法"); button.addClickHandle ...

  9. iOS js oc相互调用(JavaScriptCore 下)

    下来我们使用js调用iOS js调用iOS分两种情况 一,js里面直接调用方法 二,js里面通过对象调用方法 首先我们看第一种,直接调用方法. 其中用到了iOS的block 上代码 -(void)we ...

随机推荐

  1. RN原生调用一:安卓Toast

    首先安卓原生方法:Toast.makeText(getApplicationContext(), "默认的Toast", Toast.LENGTH_SHORT); 在RN中js如何 ...

  2. CentOS7 安装Perl

    官网:http://www.cpan.org/src/ wget https:.tar.gz cd perl- ./Configure -des -Dprefix=$HOME/localperl ma ...

  3. PHP 的命令行模式

    php CLI SAPI 内置Web Server 从版本 4.3.0 开始,PHP 提供了一种新类型的 CLI SAPI(Server Application Programming Interfa ...

  4. 用 JavaScript 将网站后台的数据变化实时更新到前端

    1.ajax短连接:客户端每隔一秒钟发一次请求,服务器收到请求后会立刻返回结果,不管有没有新数据.2.ajax长连接:客户端发送一次请求,服务器端收到请求后查询有没有新数据,如果没有新数据就阻塞这个请 ...

  5. echart 圆滑初始化化

    圆滑:主题下载对应主题js引入后注入对应名称参数方可使用主题 初始化:tab点击的时候初始化图表涉及到tab切换到的需要延迟加载否则默认宽度为100px 1.创建macarons.js文件 2.页面添 ...

  6. cyberduck的SSH登录

    1.通过配置SSH秘钥. 2.不点匿名(不要点匿名),如果非要填一个名字的话,你写root就行. 3.书签.

  7. Asp.net core 学习笔记 ( Configuration 配置 )

    参考 : https://cnblogs.com/nianming/p/7083964.html 配置写在 appsettings.json 里头 比如 { "object": { ...

  8. (转+整理)C#中使用GUID

    GUID(全局统一标识符)是指在一台机器上生成的数字,它保证对在同一时空中的所有机器都是唯一的.通常平台会提供生成GUID的API.生成算法很有意思,用到了以太网卡地址.纳秒级时间.芯片ID码和许多可 ...

  9. 20165303实验一 Java开发环境的熟悉

    实验一简单的java程序编译及运行,文件夹的创建 1.添加文件夹: 命令mkdir+文件夹名称 2.编译,运行Java程序 :javac 主类名.java java 主类名 3.带包(package) ...

  10. 一款好用的取色工具TakeColor

    简介:TakeColor,一款还算好用的取色软件,一个很小很简洁的exe文件,无需安装 使用:打开exe文件后,使用“Alt + C” 组合键即可在鼠标悬停的位置上获取到颜色值,可以获取HTML.RG ...