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

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

目录
相关文章
|
SQL XML 存储
Flowable 流程部署与删除
Flowable 流程部署与删除
1155 0
|
数据可视化 数据处理 Swift
Swift开发——简单App设计
SwiftUI教程概述:简化App设计,通过代码展示了如何创建一个计算两个数之和的界面。工程`MyCh0902`包含`ContentView.swift`,其中定义了`ContentView`和`MyView`结构体。`MyView`负责界面布局,使用`VStack`和`HStack`组织元素,如`TextField`和`Button`。点击`Button`调用`calc`方法处理输入并更新结果。界面设计可在Xcode的Inspector窗口中可视化配置。推荐将界面逻辑移到单独的`MyView.swift`文件中以清晰分离视图设计。
504 1
Swift开发——简单App设计
|
消息中间件 Linux 测试技术
【xenomai3内核解析】系列文章大纲
该博客系列详细解析了Linux实时操作系统框架Xenomai,包括实时操作系统的概念、Linux为何非实时、嵌入式实时Linux方案等。内容涵盖Xenomai内核构建、组件结构、源码介绍、实时性测试及接口应用。此外,深入探讨了双核基石IPipe、系统调用、时间子系统、任务管理、同步与互斥、内存管理、信号处理、实时IPC、POSIX IPC、实时驱动模型RTDM、Rtnet、用户态实时库libcobalt和实时性能优化等方面。适合对Linux实时系统感兴趣的读者学习研究。
452 0
【xenomai3内核解析】系列文章大纲
|
Java 开发者 Spring
Spring项目中Ordered接口的应用:全局过滤器(GlobalFilter)的顺序控制
Spring项目中Ordered接口的应用:全局过滤器(GlobalFilter)的顺序控制
690 2
|
存储 前端开发 JavaScript
无缝切换?从Vue到React
本文主要分析Vue和React在开发上的区别,帮助Vue开发者快速上手React,同时也适用于前端新手入门React。
81984 8
无缝切换?从Vue到React
|
SQL 分布式计算 数据挖掘
玩转MaxCompute SQL! 30分钟搞定数据分析挖掘
本教程将指导开发者通过MaxCompute SQL分析,快速体验MaxCompute产品,完成开通、执行SQL语句查询数据。无需进行数据同步,可直接上手体验数据分析。
1902 7
|
JavaScript 数据可视化 前端开发
Vue整合HighCharts和ECharts实现数据可视化
Vue整合HighCharts和ECharts实现数据可视化
223 0
|
SQL 关系型数据库 MySQL
|
开发工具 数据安全/隐私保护 git
git密码忘记
git密码忘记
808 0