在QWebEngine中,您可以使用QWebChannel与您的 JS 进行通信
创建一个代理对象从 JS 与 Qt 通信
// This Object will be registered in the web channel
class MyJSObj : public QObject
{
Q_OBJECT
public:
MyJSObj(QObject * poParent = Q_NULLPTR);
Q_INVOKABLE int foo(); // call from JS
};
在您的 cpp 代码中
// Create proxy object
m_poMyJSObj = new MyJSObj(this);
// Create channel
m_poWebView = new QWebEngineView(this);
QWebChannel * poChannel = new QWebChannel();
m_poWebView->page()->setWebChannel(poChannel);
// Register your proxy object
const QString oJSObjectName = "mJSQtObject"; // use in JS to call Qt functions
poChannel->registerObject(oJSObjectName, m_poMyJSObj);
在 JS 中
new QWebChannel(qt.webChannelTransport, function (channel) {
// now you retrieve your object
var JSQtObject = channel.objects.mJSQtObject;
// call Qt function from JS
var qtValue = JSQtObject.foo();
});
请注意,您必须在 HTML 端包含qwebchannel.js