QWebChannel实现与JS的交互

server/2024/12/26 9:10:13/

QWebChannel实现与JS的交互

在利用Qt框架的QWebEngineView进行嵌入浏览器开发时,可以很方便的通过
QWebChannel实现与js的交互,本节内容简单讲解js与Qt应用程序相互发送消息。

最近做项目遇到了这个问题,发现网上的例子不全,很多都是单向通讯。自己实现了这部分,简单记录一下

在使用Qt(C++)和JavaScript之间实现通信时,通常会使用一些模块和技术来使两者能够交互和传递数据。这种通信通常用于在Qt应用程序中嵌入Web内容,或者在Web页面中嵌入Qt应用程序。以下是一些常用的模块和技术,以及它们的作用

Qt WebEngine模块:

作用:Qt WebEngine是Qt中的Web引擎,允许在Qt应用程序中嵌入Web内容,包括JavaScript脚 本。它基于Chromium,提供了一个完整的Web浏览器引擎。

用法:您可以使用Qt WebEngine将Web页面嵌入到Qt应用程序中,并通过JavaScript与应用程序进行通信。这可以通过JavaScript和C++之间的信号和槽机制来实现。

Qt QWebChannel模块:

作用:QWebChannel是一个用于在Qt和JavaScript之间进行通信的模块。它使Qt中的C++对象能够通过WebSocket与嵌入在Web页面中的JavaScript进行通信。

用法:您可以使用QWebChannel在Qt应用程序和Web页面之间传递数据和调用函数。这样,您可以在Qt中暴露C++对象,使其可以在JavaScript中访问,反之亦然。

Qt QJSEngine模块:

作用:QJSEngine是一个用于在Qt应用程序中执行JavaScript代码的模块。它允许您在C++中嵌入JavaScript,并在两者之间交换数据。

用法:您可以使用QJSEngine在Qt应用程序中执行JavaScript代码,并通过QJSEngine来访问C++对象和数据。这在需要动态执行和控制JavaScript代码的情况下很有用。

JavaScript与C++交互的桥接技术:
作用:除了上述Qt提供的模块,还可以使用其他桥接技术来实现JavaScript与C++之间的通信,如Embind、Boost.JS等。这些技术允许在C++和JavaScript之间创建双向的函数调用和数据传递。
用法:您可以使用这些技术将C++函数暴露给JavaScript调用,并在C++中调用JavaScript函数。这样可以实现更紧密的集成和通信。

pro文件加入模块引用

QT += webenginewidgets webchannel

MyProjectWidget.h

#pragma once
#include <QWebEngineView>
#include <QtWebChannel>
#include <QtWidgets/QWidget>
#include <QPushButton>
#include "WebClass.h"QT_BEGIN_NAMESPACE
namespace Ui { class MyProjectWidget; }
QT_END_NAMESPACEclass MyProjectWebView;class MyProjectWidget : public QWidget {Q_OBJECTpublic:explicit MyProjectWidget(QWidget *parent = nullptr);~MyProjectWidget() override;public Q_SLOTS:void sendToJS();void receiveFromJS(const QString &data);private:Ui::MyProjectWidget *ui;QPushButton *button;QWebEngineView *webView = nullptr;QWebChannel *webChannel = nullptr;QWebEngineView *m_consoleView = nullptr;WebClass *webobj;int numer = 0;
};

MyProjectWidget.cpp

#include "MyProjectWidget.h"
#include "ui_MyProjectWidget.h"
#include <QtCore/QSysInfo>
#include <QtCore/qglobal.h>
#include <QtNetwork/QHostInfo>
#include "MyProjectWebView.h"
#include <QShortcut>MyProjectWidget::MyProjectWidget(QWidget *parent)
: QWidget(parent)
, ui(new Ui::MyProjectWidget) {ui->setupUi(this);button = new QPushButton ("Send Message to JavaScript");webView = new QWebEngineView(parent);
#ifdef QT_DEBUG// F12 调试窗口QShortcut* shortcut = new QShortcut(QKeySequence(Qt::Key_F12), this);setShortcutEnabled(shortcut->id(), true);QObject::connect(shortcut, &QShortcut::activated, this, [&]() mutable {if (m_consoleView == nullptr)m_consoleView = new QWebEngineView();webView->page()->setDevToolsPage(m_consoleView->page());webView->page()->triggerAction(QWebEnginePage::InspectElement);m_consoleView->show();});
#endif // QT_DEBUG//webView->load(QStringLiteral("qrc:/index.html"));webView->load(QUrl::fromLocalFile("F:\test_qt\js\data\index.html"));ui->vLayMain->addWidget(button);ui->vLayMain->addWidget(webView);webChannel = new QWebChannel;webobj = new WebClass();webChannel->registerObject("webobj", webobj);webView->page()->setWebChannel(webChannel);QObject::connect(button, &QPushButton::clicked, this, &MyProjectWidget::sendToJS);QObject::connect(webobj, &WebClass::strDataChanged, this, &MyProjectWidget::receiveFromJS);
}MyProjectWidget::~MyProjectWidget() {delete ui;
}void MyProjectWidget::sendToJS()
{QString numberstr = QString::number(numer++);QJsonObject json;json["key1"] = "https://kfb-dc-store.obs.cn-east-2.myhuaweicloud.com/123.xls";numberstr = QString::number(numer++);json["key2"] = "https://kfb-dc-store.obs.cn-east-2.myhuaweicloud.com/577.xls";webobj->setProperty("jsonData", json);
}void MyProjectWidget::receiveFromJS(const QString &data)
{qDebug() << "receiveFromJS:" << data;QByteArray parameterArray = data.toUtf8();QJsonDocument jsonDocument = QJsonDocument::fromJson(parameterArray);qDebug() << "jsonDocument:" << jsonDocument;
}

WebClass.h

#pragma once#include <QtCore/QObject>
#include <QJsonObject>
#include <QMessageBox>class WebClass : public QObject {Q_OBJECTQ_PROPERTY(QJsonObject jsonData MEMBER m_jsonData NOTIFY dataChanged)Q_PROPERTY(QString m_data MEMBER m_data NOTIFY strDataChanged)public:WebClass(QObject* parent = nullptr){};~WebClass() override {};signals:void dataChanged(const QJsonObject &jsonData);void strDataChanged(const QString &data);
private:QJsonObject m_jsonData;QString m_data;
};

main.cpp

#include <QApplication>
#include <QDesktopServices>
#include <QWebEnginePage>
#include <QWebEngineProfile>
#include <QWebEngineView>
#include "MyProjectWidget.h"
int main(int argc, char *argv[])
{QCoreApplication::setOrganizationName("QtExamples");QApplication app(argc, argv);MyProjectWidget myProject;myProject.show();return app.exec();
}

index.html

<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml"><head><meta charset="utf-8"><!-- 引入 ECharts 文件 --><script src="F:/test_qt/js/data/echarts.min.js"></script><title>Fetch JSON Example</title>
</head>
<p id="x">x:</p>
<p id="y">y:</p>
<body><script src="qwebchannel.js"></script><script type="text/javascript>javascript">var webobj;new QWebChannel(qt.webChannelTransport, function (channel) {webobj = channel.objects.webobj;webobj.dataChanged.connect(function (arg) {console.log(arg.key1);x.innerHTML = arg.key1;y.innerHTML = arg.key2;});});function sendMessageToQt() {console.log("12354");const json = JSON.stringify({ key: 'value' ,age: "30", city: "New York"});webobj.m_data = json;}</script><button onclick="sendMessageToQt()">Send Message to qt</button>
</body>
</html>

这样就实现了qt和H5的json对象传递了。


http://www.ppmy.cn/server/153277.html

相关文章

基于微信小程序的乡村政务服务系统springboot+论文源码调试讲解

第2章 开发环境与技术 基于web的乡村政务服务系统的编码实现需要搭建一定的环境和使用相应的技术&#xff0c;接下来的内容就是对基于web的乡村政务服务系统用到的技术和工具进行介绍。 2.1 MYSQL数据库 本课题所开发的应用程序在数据操作方面是不可预知的&#xff0c;是经常…

【深度学习-调参】Batch 大小与类别数到底有没有潜在的关系?

文章目录 深度学习中的 Batch 概念为什么关注批次内的类别分布?合理的类别分布策略1. 保持与整体数据集的类别比例一致2. 固定每个类别的采样数量3. 动态采样(自适应采样)不同场景下的选择Batch 大小与类别数之间的关系结语使用 PyTorch 的 `WeightedRandomSampler` 来平衡批…

周期性边界条件、近邻列表和原子间作用势

文章目录 1.周期性边界条件1.什么是周期性边界条件(PBC)2.周期性边界条件基本特点3.最小镜像约定4.Python实现 2.势场的有限距离截断1.原子间相互作用力2.势场截断的理论基础3.势场截断方法 3.近邻列表构筑与更新1.近邻算法&#xff1a;VerletList法2.近邻算法&#xff1a;区间…

【UI自动化】从WebDriver看Selenium与Appium的底层关联

Selenium与Appium单纯从字面上来看都有后缀ium&#xff0c;一个是Web端页面自动化工具&#xff0c;一个移动换页面自动化工具&#xff0c;他们两者之间有没有关联呢&#xff0c;是不是有底层相同的地方呢&#xff1f; 我们先来上代码看下&#xff0c;如何使用Selenium WebDrive…

智谱BigModel研习社|搭建 AI 搜索引擎 - 使用免费的Web-Search-Pro+脑图Agent智能体

**作者&#xff1a;**Cartman 文章&#xff1a;多智能体 AI 搜索引擎 点击链接&#xff0c;更多实践案例等你探索&#xff5e; #智谱 BigModel 研习社 是专业的大模型开发者交流平台&#xff0c;欢迎在评论区与我们互动&#xff01; 传统搜索引擎如今的问题在于输出很多不相关结…

Redis 基本全局命令

个人主页&#xff1a;C忠实粉丝 欢迎 点赞&#x1f44d; 收藏✨ 留言✉ 加关注&#x1f493;本文由 C忠实粉丝 原创 Redis 基本全局命令 收录于专栏[redis] 本专栏旨在分享学习Redis的一点学习笔记&#xff0c;欢迎大家在评论区交流讨论&#x1f48c; 目录 KEYS EXISTS DEL…

Llama 3 模型系列解析(一)

目录 1. 引言 1.1 Llama 3 的简介 1.2 性能评估 1.3 开源计划 1.4 多模态扩展 ps 1. 缩放法则 2. 超额训练&#xff08;Over-training&#xff09; 3. 计算训练预算 4. 如何逐步估算和确定最优模型&#xff1f; 2. 概述 2.1 Llama 3 语言模型开发两个主要阶段 2.2…

013__作用域(空间)

[ 基本难度系数 ]:★★☆☆☆ 一、基本概念 C语言中&#xff0c;标识符都有一定的可见范围&#xff0c;这些可见范围保证了标识符只能在一个有限的区域内使用&#xff0c;这个可见范围&#xff0c;被称为作用域&#xff08;scope&#xff09;。 软件开发中&#xff0c;尽量缩…