美文网首页Pythoner集中营
pyqt5的QWebEngineView 使用模板

pyqt5的QWebEngineView 使用模板

作者: 一心狮 | 来源:发表于2018-08-17 15:15 被阅读10次

说明1:关于QWebEngineView

pyqt5 已经抛弃 QtWebKit和QtWebKitWidgets,而使用最新的QtWebEngineWidgets。
QtWebEngineWidgets,是基于chrome浏览器内核引擎的。

说明2:关于左键点击页面跳转

其中,最让纠结的就是实现左键点击页面跳转了。
在chrome浏览器上,有些页面,左键点击,会直接创建一个新的tab来呈现网页。
在使用QWebEngineView时,如果不做特殊处理,这样的左键点击,是根本没有反应的。
那怎么办?就需要重写QWebEngineView的createWindow方法。

说明3:关于createWindow方法重写

在重写QWebEngineView的createWindow方法时,又有两种写法。
第一种,是直接在本窗口新建tab的方式。 (不推荐使用这种方式)
注:这种方式有个问题,因为新建的tab覆盖了原来的tab,所以,原来tab的所有信息都找不到了,如浏览,账号,密码等。

class WebEngineView(QWebEngineView):
    # 重写createwindow()
    def createWindow(self, QWebEnginePage_WebWindowType):
        return self

第二种,就是新建窗口的方式了。代码如下。(推荐使用这种方式)

【如下代码,完全复制,直接运行,即可使用】

import sys
from PyQt5.QtWidgets import *
from PyQt5.QtCore import *
from PyQt5.QtWebEngineWidgets import QWebEngineView


################################################
#######创建主窗口
################################################
class MainWindow(QMainWindow):
    def __init__(self, *args, **kwargs):
        super().__init__(*args, **kwargs)
        self.setWindowTitle('My Browser')
        self.showMaximized()

        self.webview = WebEngineView()
        self.webview.load(QUrl("https://www.baidu.com"))
        self.setCentralWidget(self.webview)




################################################
#######创建浏览器
################################################
class WebEngineView(QWebEngineView):
    windowList = []

    # 重写createwindow()
    def createWindow(self, QWebEnginePage_WebWindowType):
        new_webview =   WebEngineView()
        new_window = MainWindow()
        new_window.setCentralWidget(new_webview)
        #new_window.show()
        self.windowList.append(new_window)  #注:没有这句会崩溃!!!
        return new_webview


################################################
#######程序入门
################################################
if __name__ == "__main__":
    app = QApplication(sys.argv)
    w = MainWindow()
    w.show()
    sys.exit(app.exec_())


本文如有帮助,敬请留言鼓励。
本文如有错误,敬请留言改进。

相关文章

网友评论

  • yuchanns:请问QWebEngineView要如何获得js的事件信号?举个例子,比如说我在网页里写了个window.print()的js,目的是让QWebEngineView调用本地的打印机服务。那么我要如何接收到window.print()发出的信号。如果什么都不处理,这个window.print()会被忽视
    一心狮:@yuchanns pyqt5中,我知道的关于打印的,都写在我这篇分享里面。你进去看看吧。
    https://www.jianshu.com/p/bb8e9b3ad9f7
    yuchanns:@一心狮 谢谢。看了下QWebChannel,并进行尝试,已经实现js通信的功能,不过不是直接调用window.print(),而是通过js调用python函数进行打印。晚些时候我会写个demo分享。目前我还有一个问题,就是利用qt5的QtPrintSupport进行无预览直接打印,不知道如何排版(目标是打印热敏小票)。不知道你对QtPrintSupport是否有所研究?能否分享一下心得
    一心狮:你好,前段时间,我也正好纠结这个问题很久,查了很多资料。后来,在stackoverflow上,看到有人说QWebEngine对window.print()好像不支持,不过他提了一个曲折的方法。我后面也放弃,没去尝试了。

    这个帖子的地址是https://stackoverflow.com/questions/33217930/qtwebengine-printing-a-webpage-invoked-by-javascript

    还有相关的帖子地址是https://stackoverflow.com/questions/32711901/qwebengine-print-a-page

    你要么再研究下,如果解决了,也教教我。

本文标题:pyqt5的QWebEngineView 使用模板

本文链接:https://www.haomeiwen.com/subject/xacabftx.html