當前位置:首頁 » 網頁前端 » qt使用js腳本
擴展閱讀
webinf下怎麼引入js 2023-08-31 21:54:13
堡壘機怎麼打開web 2023-08-31 21:54:11

qt使用js腳本

發布時間: 2023-07-04 03:39:36

⑴ pyqt 怎麼使用js腳本文件

花了前後將近一個星期的時間,終於用PyQT實現了我的第一個程序。本程序實現了使用QThread後台處理數據、QThread的暫停,恢復、停止等功能。
主要有幾個問題:
1、後台單獨線程處理數據的問題;最初不明白QT在子線程中不能操作GUI的問題,因此查了很久的GUI的crash的問題
2、界面的布局;理解了gridLayout這個非常方便的布局方法。

代碼片段
# -*- coding: utf-8 -*-

"""

Mole implementing umd_MainWindow.

"""

import sys, os, re, time,sip

from PyQt4 import QtGui, QtCore

from dict4ini import DictIni

from Ui_ebook_txt import Ui_umd_MainWindow

class eBookException(Exception):

pass

class ebookParseWorker(QtCore.QThread):

'''QT中子線程內不能操作GUI界面,切記切記'''

def __init__(self, parent=None):

QtCore.QThread.__init__(self, parent)

self.exiting = False

self.isWait=False

self.data={}

def setVar(self, name, value):

self.data[name]=value

def __del__(self):

self.exiting = True

self.wait()

def buildRegx(self):

#self.alert(regx)

if self.data['chmChapterRegx'] is None:

regx='pages\[(\d+)\]\s*=\s*\[(.*)\];'

try:

self.chapterInfo=re.compile(self.data['chmChapterRegx'])

except:

self.alert('列表處理正則表達式不正確')

return False

self.chapterList=[]

return True

def getChapterList(self):

if os.path.exists(unicode(self.data['chmChapterJs'])) ==False:

self.alert('章節列表JS文件%s不存在'%(self.data['chmChapterJs']))

return False

if self.data['inputCharset'] is None or self.data['inputCharset'].strip()=='':

self.data['inputCharset']='gbk'

m=self.chapterInfo.findall(open(unicode(self.data['chmChapterJs']),'rb').read())

vol=''

for x in m:

oldChapterInfo=x[1].split(',')

newChapterInfo={}

if len(oldChapterInfo)==4:

if oldChapterInfo[3].strip('"').strip("'")[0:5]!='<img alt="" /><1:

self.alert('章節列表小於1,請檢查列表正則表達式是否正確')

return False

return self.chapterList

def run(self):

#是否觸發錯誤

error=False

self.alert("<span><strong>開始處理章節內容</strong>")

if self.data['inputCharset'] is None or self.data['inputCharset'].strip()=='':

self.data['inputCharset']='gbk'

if self.data['outputCharset'] is None or self.data['outputCharset'].strip()=='':

self.data['outputCharset']='gbk'

if self.data['oldChapterTxtDir'] is None or self.data['oldChapterTxtDir'].strip()=='' :

self.alert('原始文件存放位置為空')

error=True

if self.data['newChapterTxtDir'] is None or self.data['newChapterTxtDir'].strip()=='':

self.data['newChapterTxtDir']=self.data['oldChapterTxtDir']

if os.path.exists(unicode(self.data['newChapterTxtDir'])) ==False:

⑵ 如何利用 QT 進行 web 與本地混合應用開發

一、Qt Webkit 集成利用Qt的Webkit 集成與QtNetwork模塊,你完全可以進行本地桌面與web混合應用開發,你可以自由地混合JavaScript,樣式表,Web內容和Qt組件。 Webkit是一個非常成熟的web瀏覽引擎。Qt中集成了這個大名鼎鼎的引擎,通過QtWebkit,你可以在C++ 中執行JavaScript,或者在網頁中集成C++對象,並且通過JavaScript和這些對象進行交互。一個現代的HTML渲染引擎只 是混合開發的一半,另一半就是本地應用和渲染對象的交互。QT的Webkit 集成提供了這種解決方案:1.使用object標簽嵌入Qt Widgets組件。這可以讓使用C++代碼的Qt組件包含在網頁中,作為網頁的部分外觀。2.在JavaScript中訪問C++對象。你 可以在JavaScript環境中插入C++對象,讓網頁腳本直接訪問你的數據結構。3.在Qt中執行JavaScript。你可以在C++ 調用網頁環境中的JavaScript函數,觸發網頁事件。4.共享客戶端存儲。在JavaScript和C++中你都具有訪問資料庫的能 力,這樣當下線時也能共享大量數據。二、與嵌入的Qt對象交互使用QWebView 組件,有兩種方法可以在網頁中嵌入C++對象。你可以在網頁的JavaScript中添加C++對象,或者也可以創建一個插件,然後在網頁中使用 object標簽嵌入。
第二種方法更容易入手。當在網頁中放入 Widget組件時,它的所有public slots就像普通函數一樣被網頁中的JavaScript函數訪問。要在網頁中添加一個Widget,首先要告訴你的QWebPage對象,該Widget可用,這個通過子類化QWebPlugFactory完成,你需要 重新實現兩個方法:plugs和create。plugs方法通知網頁該Widget可用,create方法根據請求創建widget。在HTML網頁中,widgets使用object標簽創建。比如,下面這個標簽試圖創建一個 application/x-qt-colorlabel 組件。 要利用這種創建,必須要允許使用插件並且要告訴QWebpage插件的工廠類。在下面的代碼中,ColorLabelFactory將 會根據application/x-qt-colorlabel的請求創建相應實例。QWebSettings::globalSettings()->setAttribute(QWebSettings::PluginsEnabled, true); webView->page()->setPluginFactory(new ColorLabelFactory(this)); ColorLabel有一個公開的slot: chagneColor(),這個對於網頁中的JavaScript自動可用。在網頁中插入一個指向該元素的鏈接,可以以一種簡單的方式激活C++函數。Change color!a> 要反方向推進事件,必須要使你的對象在JavaScript文檔上下文中可用。要對QWebPage的每一個 QWebFrame,調用addToJavaScriptWindowObject方法。這個方法允許你根據名字把一個對象添加到JavaScipt上下 文中。webView->page()->mainFrame()->addToJavaScriptWindowObject( "eventSource", new eventSource( this ) ); 要連接剛添加對象eventSource的信號,要加上一段JavaScript代碼,使用evaluateJavaScript方法 完成。下面的代碼將把eventSource對象的signalName信號連接到一個JavaScript函數destFunction。webView->page()->mainFrame()->evaluateJavaScript( "eventSource.signalName.connect(destFunction);" ); 如果你把一個對象添加到一個以標准瀏覽器查看的JavaScript頁面中,有一個信號需要知道。每一次JavaScript 內容被清除,Frame都會釋放 javaScriptWindowObjectCleared 信號。