pyqt5的runJavaScript 使用模板

简介: runJavaScript 的说明QWebEnginePage 有一个 runJavaScript 方法,支持回调函数。使用方法1只运行JavaScript,没有回调 def run_js(self): js_string...

runJavaScript 的说明

QWebEnginePage 有一个 runJavaScript 方法,支持回调函数。

使用方法1
只运行JavaScript,没有回调

   def run_js(self):
        js_string = '''
        alert("hello,world!");
        '''

        self.webview.page().runJavaScript(js_string)

使用方法2
运行JavaScript,并存在回调

    def run_js2(self):
        js_string = '''
        function myFunction()
        {
            return document.body.scrollWidth;
        }
                
        myFunction();
        '''

        self.webview.page().runJavaScript(js_string , self.js_callback)



    # 回调函数
    def js_callback(self,result):
        print(result)
        QMessageBox.information(self, "提示", str(result))

完整代码,如下所示。

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

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()

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

        #####web页面加载完毕,调用函数
        self.webview.page().loadFinished.connect(self.run_js)
        self.webview.page().loadFinished.connect(self.run_js2)



    ########运行js脚本,没有回调########
    def run_js(self):
        js_string = '''
        alert("hello,world!");
        '''

        self.webview.page().runJavaScript(js_string)


    ########运行js脚本,有回调########
    def run_js2(self):
        js_string = '''
        function myFunction()
        {
            return document.body.scrollWidth;
        }
                
        myFunction();
        '''

        self.webview.page().runJavaScript(js_string , self.js_callback)



    # 回调函数
    def js_callback(self,result):
        print(result)
        QMessageBox.information(self, "提示", str(result))


################################################
#######创建浏览器
################################################
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_())

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

目录
相关文章
|
图形学 Python 容器
『PyQt5-基础篇』| 04 Qt Designer的初步快速了解
『PyQt5-基础篇』| 04 Qt Designer的初步快速了解
235 1
|
2月前
pyqt6 实现弹窗案例
本文介绍了如何实现一系列弹窗效果,包括基础弹窗、消息对话框、输入对话框和清除按钮。通过设置 `self.dialog = Dialog()` 可以轻松实现基础弹窗,而消息对话框则使用 `QMessageBox` 类。输入对话框支持文本、数字和下拉列表输入,清除按钮用于清空输入框内容。每个功能都通过按钮触发相应的槽函数来实现。
180 0
|
6月前
|
安全 Python
|
前端开发 索引 Python
Python高级进阶#011 pyqt5按钮QPushButton应用
Python高级进阶#011 pyqt5按钮QPushButton应用
326 0
|
索引 Python 容器
Python高级进阶#017 pyqt5下拉列表控件QComboBox
Python高级进阶#017 pyqt5下拉列表控件QComboBox
520 0
|
Python
Python高级进阶#004 pyqt5设置窗体图标
Python高级进阶#004 pyqt5设置窗体图标
239 0
|
Python
Python高级进阶#019 pyqt5菜单menu应用,新建多窗体
Python高级进阶#019 pyqt5菜单menu应用,新建多窗体
242 0
|
IDE Java 开发工具
安装PyQt5以及designer Pyside
安装PyQt5以及designer Pyside
299 0
安装PyQt5以及designer Pyside
Python Qt GUI设计:QLabel标签类(基础篇—11)
Python Qt GUI设计:QLabel标签类(基础篇—11)
Python Qt GUI设计:QLabel标签类(基础篇—11)
|
监控 Python
Python Qt GUI设计:QPushButton、QRadioButton和QCheckBox按钮类(基础篇—12)
Python Qt GUI设计:QPushButton、QRadioButton和QCheckBox按钮类(基础篇—12)
Python Qt GUI设计:QPushButton、QRadioButton和QCheckBox按钮类(基础篇—12)