由于QWebFrame 提供了一个addToJavaScriptWindowObject()接口, 所以在QT Webkit下添加一个自定义的
Javascript对象就变得非常的容易,要注意在跨页面的时候,该对象会被清除,所以你只要重新加回来
就可以了, 这一点跟GTK类似, 只要捕获WindowObjectCleared信号,在该信号处理函数里面执行
addToJavaScriptWindowObject()就可以了。
这种方法不用去修改Webkit的核心代码WebCore或者JavascriptCore, 所有工作都在应用层面实现,
可以说是简单又实用。
具体可以参考如下源代码:
// 实现一个新类
class QFoo : public QObject
{
Q_OBJECT
public:
QFoo(QObject *parent) {}
void initialize(QWebView *wv);
public slots:
void print(const QString &msg);
private slots:
void addObject();
private:
QWebFrame *wf;
};
void QFoo::setWebView(QWebView *wv)
{
wf = wv->page()->mainFrame();
// Add to the javascript window object
addObject();
// connect the signal for javascript window object cleared, which happened
// at page switching etc.
connect(wf, SIGNAL(javaScriptWindowObjectCleared()), this, SLOT(addObject()));
}
void QFoo::addObject()
{
wf->addToJavaScriptWindowObject(QString("QFoo"), this);
}
void QFoo::print(const QString &msg)
{
qDebug() << "Output the message " << msg;
}
// 测试主函数
int main(int argc, char *argv[])
{
QApplication test(argc, argv);
QWebView *wv = new QWebView();
QFoo *foo = new QFoo(wv);
foo->initialize(wv);
wv->setUrl(QUrl("foo.html"));
wv->show();
return test.exec();
}
HTML测试代码很简单:
<script>
QFoo.print("Hello world!");
</script>