您需要在继承自 QObject 的类中定义要调用的方法。
从 QWebView,您可以调用page()
以检索其 QWebPage。使用 QWebPage,您可以调用mainFrame()
以检索其 QWebFrame。QWebFrame 有一个addToJavaScriptWindowObject()
方法可以让你将 QObject 绑定到 web 上下文中:
class MyObject {
public slots:
void doSomething();
};
MyObject *foo = new MyObject;
myWebView->page()->mainFrame()->addJavaScriptToWindowObject("somefoo", foo);
然后从javascript方面,我可以通过上面提供的名称(在本例中为“somefoo”)引用它来调用我的QObject上的任何插槽或Q_INVOKABLE方法:
somefoo.doSomething();
更多信息在这里:http: //qt-project.org/doc/qt-5.1/qtwebkit/qwebframe.html#addToJavaScriptWindowObject
更新- 添加原始示例。
主.cpp:
#include <QApplication>
#include <QDebug>
#include <QWebFrame>
#include <QWebPage>
#include <QWebView>
class MyJavaScriptOperations : public QObject {
Q_OBJECT
public:
Q_INVOKABLE void sumOfNumbers(int a, int b) {
qDebug() << a + b;
}
};
int main(int argc, char *argv[])
{
QApplication a(argc, argv);
QWebView *view = new QWebView();
view->resize(400, 500);
view->page()->mainFrame()->addToJavaScriptWindowObject("myoperations", new MyJavaScriptOperations);
view->load(QUrl("file:///path/to/my/index.html"));
view->show();
return a.exec();
}
#include "main.moc"
索引.html:
<html>
<body>
<script type="text/javascript">
myoperations.sumOfNumbers(12, 23);
</script>
</body>
</html>