调用Javascript代码是通过QWebFrame类的evaluateJavaScript函数来实现的。下面是一个例子,我写了一个本地的HTML文件如下:
<html>
<head>
<script type="text/javascript" src="test.js">
</script>
</head>
<body>
<form>
<input type="button" value="Click me!" οnclick="Test()" >
</form>
</body>
</html>
这个简单的网页有一个按钮,点击后调用Test函数,而Test函数是在一个test.js的Javascript文件,文件内容如下:
function Test() {
alert("Test");
}
function add() {
return 33;
}
建立一个工程,加入一个QWebView,初始化载入Test.html,
ui.webView->load(QUrl("test.html"));
再加入一个按钮,为了调用Javascript,然后在按钮点击时就可以用C++代码:
ui.webView->page()->mainFrame()->evaluateJavaScript("Test()");
运行后可以看到网页弹出了一个提示框。这和在网页里面点击按钮的效果是一样的。
附注:
如果是qt调用js函数,js函数带参数时,要多注意, 在qt里该函数调用方法要写成:
QString method = QString("jsFunction(\"%1\", \"%2\")").arg(param1).arg(param2);
m_web_view->page()->mainFrame()->evaluateJavaScript(method);
参数两边的引号必不可少,而且要转义符转义。