亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術文章
文章詳情頁

python GUI庫圖形界面開發之PyQt5瀏覽器控件QWebEngineView詳細使用方法

瀏覽:7日期:2022-08-06 11:21:06
PyQt5瀏覽器控件QWebEngineView

PyQt5使用QWebEngineView控件來展示HTML頁面,對老版本的QWebView類不在進行維護,因為QWebEngineView使用CHromium內核可以給用戶帶來更好的體驗

QWebEngineView類中常用方法 方法 描述 load(QUrl url) 加載指定的URL并顯示 setHtml(QString&html) 將網頁視圖的內容設置為指定的HTML內容

QWebEngineView控件使用load()函數加載一個Web頁面,實際上就是使用HTTP Get方法加載web頁面,這個控件可以加載本地的web頁面,也可以加載外部的WEb頁面,其核心代碼如下

view=QWebEngineView()view.load(QUrl(’https://www.jb51.net’))view.show()QWebEngineView加載顯示外部的web頁面實例

import sysfrom PyQt5.QtCore import *from PyQt5.QtGui import *from PyQt5.QtWidgets import *from PyQt5.QtWebEngineWidgets import *class MainWindow(QMainWindow): def __init__(self): super(MainWindow, self).__init__() self.setWindowTitle(’加載外部網頁的例子’) self.setGeometry(5,30,1355,730) self.browser=QWebEngineView() #加載外部的web界面 self.browser.load(QUrl(’https://www.jb51.net’)) self.setCentralWidget(self.browser)if __name__ == ’__main__’: app=QApplication(sys.argv) win=MainWindow() win.show() app.exit(app.exec_())

運行效果圖如下

python GUI庫圖形界面開發之PyQt5瀏覽器控件QWebEngineView詳細使用方法

在這里,我輸入的url是我的博客地址,所以加載的也就是這個網址請求的web界面

QWebEngineView加載并顯示嵌入的HTML代碼

import sysfrom PyQt5.QtCore import *from PyQt5.QtGui import *from PyQt5.QtWidgets import *from PyQt5.QtWebEngineWidgets import *class MainWindow(QMainWindow): def __init__(self): super(MainWindow, self).__init__() self.setWindowTitle(’加載本地網頁的例子’) self.setGeometry(5,30,1355,730) self.browser=QWebEngineView() # #加載外部的web界面 # url=r’index.html’ # self.browser.load(QUrl(url)) self.browser.setHtml(’’’<!DOCTYPE html><html lang='en'><head> <meta charset='UTF-8'> <title>Title</title></head><body><h1>Hello PyQt5</h1><h1>Hello PyQt5</h1><h1>Hello PyQt5</h1><h1>Hello PyQt5</h1><h1>Hello PyQt5</h1></body></html>’’’) self.setCentralWidget(self.browser)if __name__ == ’__main__’: app=QApplication(sys.argv) win=MainWindow() win.show() app.exit(app.exec_())

運行圖片如下

python GUI庫圖形界面開發之PyQt5瀏覽器控件QWebEngineView詳細使用方法

注意使用QWebEngineView對象的setHTML()函數渲染HTml頁面時,如果頁面中使用的JavaScript代碼超過2M,程序渲染就會失敗

QWebEngineView調用JavaScript代碼實例

通過QWebEnginePage類的runJavaScript(str,Callable)函數可以方便地實現PyQt和HTML、JavaScript的雙向通信,也實現了python代碼和Html,JavaScript代碼的解耦,便于開發人員進行分工協作,在PyQt對象中,訪問JavaScript的核心代碼如下

QWebEnginePage.runJavaScript(str,Callable)

完整代碼

import sysfrom PyQt5.QtWebEngineWidgets import QWebEngineViewfrom PyQt5.QtWidgets import QApplication, QWidget, QVBoxLayout, QPushButton# 創建一個 application實例app = QApplication(sys.argv)win = QWidget()win.setWindowTitle(’Web頁面中的JavaScript與 QWebEngineView交互例子’)# 創建一個垂直布局器layout = QVBoxLayout()win.setLayout(layout)# 創建一個 QWebEngineView 對象view = QWebEngineView()view.setHtml(’’’ <html> <head> <title>A Demo Page</title> <script language='javascript'> // Completes the full-name control and // shows the submit button function completeAndReturnName() { var fname = document.getElementById(’fname’).value; var lname = document.getElementById(’lname’).value; var full = fname + ’’ + lname; document.getElementById(’fullname’).value = full; document.getElementById(’submit-btn’).style.display = ’block’; return full; } </script> </head> <body> <form> <label for='fname'>First name:</label> <input type='text' name='fname' id='fname'></input> <br /> <label for='lname'>Last name:</label> <input type='text' name='lname' id='lname'></input> <br /> <label for='fullname'>Full name:</label> <input disabled type='text' name='fullname' id='fullname'></input> <br /> <input type='submit' id='submit-btn'></input> </form> </body> </html>’’’)# 創建一個按鈕去調用 JavaScript代碼button = QPushButton(’設置全名’)def js_callback( result ): print(result)def complete_name(): view.page().runJavaScript(’completeAndReturnName();’, js_callback)# 按鈕連接 ’complete_name’槽,當點擊按鈕是會觸發信號button.clicked.connect(complete_name)# 把QWebView和button加載到layout布局中layout.addWidget(view)layout.addWidget(button)# 顯示窗口和運行appwin.show()sys.exit(app.exec_())

python GUI庫圖形界面開發之PyQt5瀏覽器控件QWebEngineView詳細使用方法

代碼分析

在本例中,初始化一個QWebEngineView對象,對象名稱View,然后通過View。page()函數獲得一個QWebEnginePage對象,就可以訪問整個web界面了。這個QWebEnginePage對象有一個異步的runJavaScript()函數,需要一個回調函數接收結果,其核心代碼如下

def js_callback( result ): print(result)def complete_name(): view.page().runJavaScript(’completeAndReturnName();’, js_callback)

本文詳細介紹了PyQt5瀏覽器控件QWebEngineView的使用方法,包括使用QWebEngineView調用JavaScript代碼,更多關于PyQt5瀏覽器控件QWebEngineView的使用方法請查看下面的相關鏈接

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 毛片毛片毛片毛片毛片毛片 | 91视频免费网址 | 韩国黄色一级视频 | 丁香六月婷婷精品免费观看 | 边做边摸边揉的免费视频 | 国产真人毛片一级视频 | 91久久香蕉国产线看观看软件 | 日韩在线观看精品 | 午夜一级视频 | 在线看片免费 | 精品第一页| 91久久国产成人免费观看资源 | 精品一区二区视频 | 视频免费1区二区三区 | 亚拍精品一区二区三区 | 中文字幕一级片 | 嘿嘿视频在线观看 成人 | 午夜剧场刺激性爽免费视频 | 97视频免费在线观看 | 欧美日韩在线免费观看 | 人人狠狠综合88综合久久 | 国产在线一区二区三区在线 | 任我爽在线视频精品凹凸精品分类 | 日日干夜夜爱 | 久久精品视频3 | 91精品全国免费观看含羞草 | 国产偷窥自拍视频 | 奇米中文字幕 | 伊人激情久久综合中文字幕 | 国产视频手机在线观看 | 国产欧美综合精品一区二区 | 手机日韩理论片在线播放 | 亚洲高清在线 | 黄色爱爱视频 | 97视频在线免费观看 | 日本黄色美女视频 | 一区二区三区四区视频在线观看 | 欧美一级黄视频 | 日本v片免费一区二区三区 日本wwwwwxxxxx | 免费一级乱子伦片 | 久久婷婷综合五月一区二区 |