如何从PyQT调用javascript函数

前端之家收集整理的这篇文章主要介绍了如何从PyQT调用javascript函数前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我正在尝试使用 python与谷歌地图进行互动.我在PyQT中使用QWebView构建了一个应用程序. QWebView加载本地html页面,如下所示:
  1. browser = QwebView()
  2. browser.load(QUrl("file:///c:/main.html"))
  3. frame = browser.page().currentFrame()
  4. frame.evaluateJavaScript(QString("addMarker(-33.89,151.275)"))

html页面如下:

  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <Meta name="viewport" content="initial-scale=1.0,user-scalable=no" />
  5. <style type="text/css">
  6. html { height: 100% }
  7. body { height: 100%; margin: 0px; padding: 0px }
  8. #map_canvas { height: 100% }
  9. </style>
  10. <script type="text/javascript"
  11. src="http://maps.google.com/maps/api/js?sensor=false">
  12. </script>
  13. <script type="text/javascript">
  14. var map;
  15. function initialize() {
  16. var latlng = new google.maps.LatLng(-34.397,150.644);
  17. var myOptions = {
  18. zoom: 8,center: latlng,mapTypeId: google.maps.MapTypeId.ROADMAP
  19. };
  20. map = new google.maps.Map(document.getElementById("map_canvas"),myOptions);
  21. }
  22.  
  23. function addMarker(lat,lng) {
  24. var myLatLng = new google.maps.LatLng(lat,lng);
  25. var beachMarker = new google.maps.Marker({position: myLatLng,map: map
  26. });
  27. }
  28.  
  29. </script>
  30. </head>
  31. <body onload="initialize();">
  32. <div id="map_canvas" style="width:100%; height:100%"></div>
  33. </body>
  34. </html>

如何从Python调用addMarker?

我试过从HTML调用addMarker(添加了对onload调用调用),我尝试使用python中的一个简单的javascript表达式(frame.evaluateJavaScript(“alert(5)”)).这两个都有效,所以我知道addMarker和evaluateJavaScript可以工作,我只是不知道如何.

我也尝试在frame.documentElement()对象上调用evaluateJavaScript(“addMarker(-33.89,151.275)”),但这也不起作用.

解决方法

错误是我需要等待页面加载.我添加了一个连接到evaluateJavaScript(“addMarker(-33.89,151.275)”)调用的按钮.当我单击按钮(加载页面后)时,标记已按预期添加.

猜你在找的JavaScript相关文章