pyqt5解决qtdesigner中没有QWebEngineView、内存泄露

三三

实现逻辑和代码的分离,先在designer中用容器占位,随后在实例化UI中添加QWebEngineView控件,这样子可以实现动态修改。

其实用pyuic转化好之后,直接在转化之后的代码中修改也行,但是经过我的实测发现,QWebEngineView在使用setHtml时,会造成内存泄露,因此需要销毁重建,于是产生了此贴

一、在qtdesigner中设计好界面

二、使用pyuic将ui文件转化为py文件,

designer中为容器加布局是点击layout,往QFrame中拖,转化之后的代码如下(我稍微动手改了一下,删了一个layout,反正大致原理如下,把边距都设为0,designer里都能改):

import sys
from PyQt5 import QtCore, QtGui, QtWidgets
from PyQt5.QtWebEngineWidgets import QWebEngineView
from PyQt5.QtWidgets import QApplication


class Ui_Form(object):
    def setupUi(self, Form):
        Form.setObjectName("Form")
        Form.resize(664, 609)

        # 在QT设计师中使用QFrame占位
        self.frame = QtWidgets.QFrame(Form)
        self.frame.setGeometry(QtCore.QRect(90, 100, 441, 371))
        self.frame.setFrameShape(QtWidgets.QFrame.StyledPanel)
        self.frame.setFrameShadow(QtWidgets.QFrame.Raised)
        self.frame.setObjectName("frame")

        # 在QFrame上创建垂直布局
        self.horizontalLayout = QtWidgets.QHBoxLayout(self.frame)
        self.horizontalLayout.setContentsMargins(0, 0, 0, 0)
        self.horizontalLayout.setSpacing(0)
        self.horizontalLayout.setObjectName("horizontalLayout")

        self.retranslateUi(Form)
        QtCore.QMetaObject.connectSlotsByName(Form)

    def retranslateUi(self, Form):
        _translate = QtCore.QCoreApplication.translate
        Form.setWindowTitle(_translate("Form", "Form"))


三、单继承实例化UI,并加入逻辑代码

if __name__ == '__main__':
    class MyWindow(QtWidgets.QWidget):
        def __init__(self):
            super(MyWindow, self).__init__()
            # 实例化UI
            self.UI = Ui_Form()
            self.UI.setupUi(self)  # def setupUi(self, Form),现在self是QtWidgets.QWidget,对应传至形参Form

            # 逻辑代码
            self.UI.webHolder = QWebEngineView(self.UI.frame)
            self.UI.webHolder.setHtml('<div>hello world</div>')
            self.UI.horizontalLayout.addWidget(self.UI.webHolder)

        def reset_web(self):
            """之后更新qwebengineview界面"""
            self.UI.webHolder.deleteLater()  # 每次设置新内容最好销毁一下,不然会内存泄露,无限变大
            self.UI.webHolder = QWebEngineView(self.UI.frame)
            self.UI.webHolder.setHtml('<div>新网页</div>')
            self.UI.horizontalLayout.addWidget(self.UI.webHolder)


    app = QApplication(sys.argv)
    mywindow = MyWindow()
    mywindow.show()
    sys.exit(app.exec_())
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
如果你在使用Qt QWebEngineView时无法捕获到a标签的点击事件,可能是因为默认情况下,QWebEngineView不会向下传递这个事件。为了解决这个问题,你需要自定义QWebEnginePage类,并重写acceptNavigationRequest方法来捕获a标签的点击事件。 以下是一个简单的示例代码: ```python from PyQt5.QtCore import QUrl from PyQt5.QtWidgets import QApplication from PyQt5.QtWebEngineWidgets import QWebEngineView, QWebEnginePage class MyWebEnginePage(QWebEnginePage): def acceptNavigationRequest(self, url, type, isMainFrame): if type == QWebEnginePage.NavigationTypeLinkClicked: # 在这里处理a标签的点击事件 print('a标签点击事件:', url) return False return super().acceptNavigationRequest(url, type, isMainFrame) app = QApplication([]) view = QWebEngineView() page = MyWebEnginePage(view) view.setPage(page) view.load(QUrl('https://www.baidu.com')) view.show() app.exec_() ``` 在这个代码,我们自定义了一个`MyWebEnginePage`类,继承自`QWebEnginePage`类,并重写了`acceptNavigationRequest`方法,当用户点击a标签时,会触发该方法,我们可以在这里编写我们的逻辑代码。然后我们创建了一个QWebEngineView实例,并将其page设置为我们自定义的`MyWebEnginePage`类的实例。最后,我们加载了百度网站,并显示了QWebEngineView。 当你运行这个代码后,在QWebEngineView点击任何一个a标签时,都会触发`acceptNavigationRequest`方法,并将a标签的url打印出来。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值