当前位置:   article > 正文

PyQt5挖坑_qwebengineview --disable-web-security

qwebengineview --disable-web-security

PyQt5的QWebEngineView加载的页面,点击事件,有的有效,有的无效,就算是重写了WebEnginePage的acceptNavigationRequest也还是一样。参考了一篇C++的代码,终于解决。

WebEngineView的createWindow重写有技巧,先贴出代码,以后再慢慢看。

  1. class WebEnginePage(QWebEnginePage):
  2. def acceptNavigationRequest(self, url, _type, isMainFrame):
  3. print("openUrl")
  4. if _type == QWebEnginePage.NavigationTypeLinkClicked:
  5. # QtGui.QDesktopServices.openUrl(url)
  6. pass
  7. return False
  8. return True
  9. class WebEngineView(QWebEngineView):
  10. def __init__(self, *args, **kwargs):
  11. QWebEngineView.__init__(self, *args, **kwargs)
  12. self.setPage(WebEnginePage(self))
  13. def createWindow(self, QWebEnginePage_WebWindowType):
  14. r=WebEngineView(self.parent())
  15. r.setPage(WebEnginePage(self.page()))
  16. return r

这样就能保证,页面的超链接点击都会有反应。坑真是多。

https://bugreports.qt.io/browse/QTBUG-56637

有的教程关于内部打开链接是createWindow重写,写返回self,但我这种写法会奔溃,不知道为什么,以后再说吧。我目前需求是外部浏览器打开。

 

qt集成的是Chromium浏览器,所以可以充分利用它的好处,比如,关掉同源策略,让js的xhr可以跨域。

  1. sys.argv.append('--disable-web-security')
  2. app = QApplication(sys.argv)

这一点真的是美滋滋啊,大部分代码都能在js端解决了,不用js和python,交互来交互去,影响效率。

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/天景科技苑/article/detail/839049
推荐阅读
相关标签
  

闽ICP备14008679号