本篇文章給大家分享的是有關(guān)怎么在python中使用QWebEngineView控件,小編覺(jué)得挺實(shí)用的,因此分享給大家學(xué)習(xí),希望大家閱讀完這篇文章后可以有所收獲,話不多說(shuō),跟著小編一起來(lái)看看吧。
創(chuàng)新互聯(lián)堅(jiān)持“要么做到,要么別承諾”的工作理念,服務(wù)領(lǐng)域包括:成都網(wǎng)站建設(shè)、網(wǎng)站建設(shè)、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣等服務(wù),滿足客戶于互聯(lián)網(wǎng)時(shí)代的南山網(wǎng)站設(shè)計(jì)、移動(dòng)媒體設(shè)計(jì)的需求,幫助企業(yè)找到有效的互聯(lián)網(wǎng)解決方案。努力成為您成熟可靠的網(wǎng)絡(luò)建設(shè)合作伙伴!PyQt5使用QWebEngineView控件來(lái)展示HTML頁(yè)面,對(duì)老版本的QWebView類不在進(jìn)行維護(hù),因?yàn)镼WebEngineView使用CHromium內(nèi)核可以給用戶帶來(lái)更好的體驗(yàn)
方法 | 描述 |
---|---|
load(QUrl url) | 加載指定的URL并顯示 |
setHtml(QString&html) | 將網(wǎng)頁(yè)視圖的內(nèi)容設(shè)置為指定的HTML內(nèi)容 |
QWebEngineView控件使用load()函數(shù)加載一個(gè)Web頁(yè)面,實(shí)際上就是使用HTTP Get方法加載web頁(yè)面,這個(gè)控件可以加載本地的web頁(yè)面,也可以加載外部的WEb頁(yè)面,其核心代碼如下
view=QWebEngineView() view.load(QUrl('https://www.jb51.net')) view.show()
import sys from 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('加載外部網(wǎng)頁(yè)的例子') 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_())
運(yùn)行效果圖如下
在這里,我輸入的url是我的博客地址,所以加載的也就是這個(gè)網(wǎng)址請(qǐng)求的web界面
import sys from 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('加載本地網(wǎng)頁(yè)的例子') 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> <h2>Hello PyQt5</h2> <h2>Hello PyQt5</h2> <h2>Hello PyQt5</h2> <h2>Hello PyQt5</h2> <h2>Hello PyQt5</h2> </body> </html>''') self.setCentralWidget(self.browser) if __name__ == '__main__': app=QApplication(sys.argv) win=MainWindow() win.show() app.exit(app.exec_())
運(yùn)行圖片如下
注意使用QWebEngineView對(duì)象的setHTML()函數(shù)渲染HTml頁(yè)面時(shí),如果頁(yè)面中使用的JavaScript代碼超過(guò)2M,程序渲染就會(huì)失敗
通過(guò)QWebEnginePage類的runJavaScript(str,Callable)函數(shù)可以方便地實(shí)現(xiàn)PyQt和HTML、JavaScript的雙向通信,也實(shí)現(xiàn)了python代碼和Html,JavaScript代碼的解耦,便于開(kāi)發(fā)人員進(jìn)行分工協(xié)作,在PyQt對(duì)象中,訪問(wèn)JavaScript的核心代碼如下
QWebEnginePage.runJavaScript(str,Callable)
完整代碼
import sys from PyQt5.QtWebEngineWidgets import QWebEngineView from PyQt5.QtWidgets import QApplication, QWidget, QVBoxLayout, QPushButton # 創(chuàng)建一個(gè) application實(shí)例 app = QApplication(sys.argv) win = QWidget() win.setWindowTitle('Web頁(yè)面中的JavaScript與 QWebEngineView交互例子') # 創(chuàng)建一個(gè)垂直布局器 layout = QVBoxLayout() win.setLayout(layout) # 創(chuàng)建一個(gè) QWebEngineView 對(duì)象 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> ''') # 創(chuàng)建一個(gè)按鈕去調(diào)用 JavaScript代碼 button = QPushButton('設(shè)置全名') def js_callback( result ): print(result) def complete_name(): view.page().runJavaScript('completeAndReturnName();', js_callback) # 按鈕連接 'complete_name'槽,當(dāng)點(diǎn)擊按鈕是會(huì)觸發(fā)信號(hào) button.clicked.connect(complete_name) # 把QWebView和button加載到layout布局中 layout.addWidget(view) layout.addWidget(button) # 顯示窗口和運(yùn)行app win.show() sys.exit(app.exec_())
代碼分析
在本例中,初始化一個(gè)QWebEngineView對(duì)象,對(duì)象名稱View,然后通過(guò)View。page()函數(shù)獲得一個(gè)QWebEnginePage對(duì)象,就可以訪問(wèn)整個(gè)web界面了。這個(gè)QWebEnginePage對(duì)象有一個(gè)異步的runJavaScript()函數(shù),需要一個(gè)回調(diào)函數(shù)接收結(jié)果,其核心代碼如下
def js_callback( result ): print(result) def complete_name(): view.page().runJavaScript('completeAndReturnName();', js_callback)
以上就是怎么在python中使用QWebEngineView控件,小編相信有部分知識(shí)點(diǎn)可能是我們?nèi)粘9ぷ鲿?huì)見(jiàn)到或用到的。希望你能通過(guò)這篇文章學(xué)到更多知識(shí)。更多詳情敬請(qǐng)關(guān)注創(chuàng)新互聯(lián)成都網(wǎng)站設(shè)計(jì)公司行業(yè)資訊頻道。
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無(wú)理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國(guó)服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡(jiǎn)單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場(chǎng)景需求。
當(dāng)前文章:怎么在python中使用QWebEngineView控件-創(chuàng)新互聯(lián)
標(biāo)題URL:http://bm7419.com/article4/ddjjie.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站導(dǎo)航、服務(wù)器托管、網(wǎng)站策劃、網(wǎng)站營(yíng)銷、定制開(kāi)發(fā)、動(dòng)態(tài)網(wǎng)站
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容