关于QT实现和html页面的交互

1.通过QWebEngineView引入html页面, .pro文件中引入webenginewidgets,webengine,network,webchannel组件

组件可以通过QT软件根目录的MaintenanceTool.exe安装,设置中选择临时资料档案库,临时资料档案库可以在网上找资源路径(我用的是:http://mirrors.ustc.edu.cn/qtproject/online/qtsdkrepository/mac_x64/root/qt/,如果临时资料档案库测试是失败的,可能是因为没有装visual studio),选择添加或移除组件

2.建立连接html和QT的QObject类

mychannel.h

#ifndef MYCHANNEL_H
#define MYCHANNEL_H

#include <QObject>
#include <QDebug>
#include <QWebChannel>

class MyChannel : public QObject
{
    Q_OBJECT
public:
    explicit MyChannel(QObject *parent = nullptr);
    void sendSetViewPort();

signals:
    void setViewPort();//QT给html页面发送的信号

};

#endif // MYCHANNEL_H

mychannel.cpp

#include "mychannel.h"

MyChannel::MyChannel(QObject *parent) : QObject(parent)
{

}

void MyChannel::sendSetViewPort()
{
    qDebug()<<"----------------alert==========";
    emit setViewPort();
}

mapload.cpp(加载html页面的cpp文件)

void MapLoad::initMap(){
    _myChannel = new MyChannel(this);
    QWebChannel* web_channel = new QWebChannel(this);
    //html文件用的时候可以知道用的是哪个webchannel
    web_channel->registerObject("qtChannel",_myChannel);
	//加载html页面的widget
    view = new QWebEngineView(ui->widget_map_content);
    view->load(QUrl("qrc:/font/images/static/mapindex.html"));
    view->page()->setWebChannel(web_channel);
    view->show();
    //点击按钮的时候给发给MapLoad发送点击事件的信号
    QObject::connect(ui->button_right, &QPushButton::clicked, this, &MapLoad::sendSetViewPort);

}

void MapLoad::sendSetViewPort()
{
    qDebug()<<"----------------alert";
    _myChannel->sendSetViewPort();
}

mapload.h

private:
    Ui::MapLoad *ui;
    QWebEngineView *view=nullptr;
    MyChannel* _myChannel=nullptr;
private slots:
    void on_button_right_clicked();
    void sendSetViewPort();

mapindex.html

<script type="text/javascript" src="./qwebchannel.js"></script>
<script type="text/javascript">
  var mchannel;
  window.onload = function () {
    if (typeof qt != 'undefined') {
      new QWebChannel(qt.webChannelTransport, function (channel) {
        channel.objects.qtChannel.setViewPort.connect(mapSetView);
      })
    } else {
      alert("qt对象获取失败!");
    }
  }
 function mapSetView() {
    console.log("nihao");
  }
</script>

参考:https://blog.csdn.net/qq_41961619/article/details/107104622

  • 0
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
实现QtHTML中输入框的数据交互,可以使用QWebChannel库。以下是一些基本步骤: 1. 在Qt应用程序中创建一个QWebChannel对象,并将其绑定到一个QWebEngineView或QWebView对象上: ``` QWebEngineView* view = new QWebEngineView(parent); QWebChannel* channel = new QWebChannel(view->page()); view->page()->setWebChannel(channel); ``` 2. 在Qt应用程序中创建一个QObject子类的对象,该对象将用于在QtHTML之间进行通信。可以使用Q_PROPERTY宏将对象的属性公开给HTML页面: ``` class MyObject : public QObject { Q_OBJECT Q_PROPERTY(QString text READ text WRITE setText NOTIFY textChanged) public: QString text() const; void setText(const QString& text); signals: void textChanged(const QString& text); private: QString m_text; }; QString MyObject::text() const { return m_text; } void MyObject::setText(const QString& text) { if (text != m_text) { m_text = text; emit textChanged(m_text); } } ``` 3. 在Qt应用程序中将该对象注册到QWebChannel中: ``` MyObject* myObject = new MyObject(); channel->registerObject("myObject", myObject); ``` 4. 在HTML页面中,使用JavaScript代码创建一个QWebChannel对象,并将其绑定到页面中的一个元素上。然后,使用该对象的connectTo方法连接到Qt应用程序中的QWebChannel对象: ``` <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>Qt and HTML Data Exchange</title> <script src="qrc:///qtwebchannel/qwebchannel.js"></script> <script> var myObject; new QWebChannel(qt.webChannelTransport, function(channel) { myObject = channel.objects.myObject; myObject.textChanged.connect(function(text) { document.getElementById("text").value = text; }); }); function setText() { var text = document.getElementById("text").value; myObject.text = text; } </script> </head> <body> <input type="text" id="text"> <button onclick="setText()">Set Text</button> </body> </html> ``` 在上面的HTML代码中,JavaScript代码使用QWebChannel对象连接到Qt应用程序中的QWebChannel对象,并监听MyObject对象的textChanged信号。当该信号发出时,JavaScript代码将文本框的值更新为MyObject对象的属性值。同时,按钮的点击事件会将文本框的值设置为MyObject对象的属性值。 这样,Qt应用程序和HTML页面中的输入框就可以实现数据交互了。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值