精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

如何利用 QT 進行 web 與本地混合應用開發(fā)

移動開發(fā)
Webkit是一個非常成熟的web瀏覽引擎。Qt中集成了這個大名鼎鼎的引擎,通過QtWebkit,你可以在C++ 中執(zhí)行JavaScript,或者在網(wǎng)頁中集成C++對象,并且通過JavaScript和這些對象進行交互。

如何利用 QT 進行 web 與本地混合應用開發(fā)是本文要講述的內(nèi)容,Qt提供了本地 C++對象與JavaScript的無縫集成,是進行本地與web混合應用開發(fā)的理想平臺。

一、Qt Webkit 集成

利用QtWebkit 集成與QtNetwork模塊,你完全可以進行本地桌面與web混合應用開發(fā),你可以自由地混合JavaScript,樣式表,Web內(nèi)容和Qt組件。 Webkit是一個非常成熟的web瀏覽引擎。Qt中集成了這個大名鼎鼎的引擎,通過QtWebkit,你可以在C++ 中執(zhí)行JavaScript,或者在網(wǎng)頁中集成C++對象,并且通過JavaScript和這些對象進行交互。

一個現(xiàn)代的HTML渲染引擎只 是混合開發(fā)的一半,另一半就是本地應用和渲染對象的交互。QTWebkit 集成提供了這種解決方案:

1.使用object標簽嵌入Qt Widgets組件。這可以讓使用C++代碼的Qt組件包含在網(wǎng)頁中,作為網(wǎng)頁的部分外觀。

2.在JavaScript中訪問C++對象。你 可以在JavaScript環(huán)境中插入C++對象,讓網(wǎng)頁腳本直接訪問你的數(shù)據(jù)結(jié)構(gòu)。

3.在Qt中執(zhí)行JavaScript。你可以在C++ 調(diào)用網(wǎng)頁環(huán)境中的JavaScript函數(shù),觸發(fā)網(wǎng)頁事件。

4.共享客戶端存儲。在JavaScript和C++中你都具有訪問數(shù)據(jù)庫的能 力,這樣當下線時也能共享大量數(shù)據(jù)。

二、與嵌入的Qt對象交互

使用 QWebView 組件,有兩種方法可以在網(wǎng)頁中嵌入C++對象。你可以在網(wǎng)頁的JavaScript中添加C++對象,或者也可以創(chuàng)建一個插件,然后在網(wǎng)頁中使用 object標簽嵌入。

第二種方法更容易入手。當在網(wǎng)頁中放入 Widget組件時,它的所有public slots就像普通函數(shù)一樣被網(wǎng)頁中的JavaScript函數(shù)訪問。

要在網(wǎng)頁中添加一個Widget,首先要告訴你的QWebPage對象,該Widget可用,這個通過子類化QWebPlugFactory完成,你需要 重新實現(xiàn)兩個方法:plugs和create。plugs方法通知網(wǎng)頁該Widget可用,create方法根據(jù)請求創(chuàng)建widget。

在 HTML網(wǎng)頁中,widgets使用object標簽創(chuàng)建。比如,下面這個標簽試圖創(chuàng)建一個 application/x-qt-colorlabel 組件。

  1. <object type="application/x-qt-colorlabel" width="50px" height="20px" id="label" />  

要利用這種創(chuàng)建,必須要允許使用插件并且要告訴QWebpage插件的工廠類。在下面的代碼中,ColorLabelFactory將 會根據(jù)application/x-qt-colorlabel的請求創(chuàng)建相應實例。

  1. QWebSettings::globalSettings()->setAttribute(QWebSettings::PluginsEnabled, true);   
  2. webView->page()->setPluginFactory(new  ColorLabelFactory(this));  

ColorLabel有一個公開的slot: chagneColor(),這個對于網(wǎng)頁中的JavaScript自動可用。在網(wǎng)頁中插入一個指向該元素的鏈接,可以以一種簡單的方式激活C++函數(shù)。

  1. <a href='javascript:document.getElementById("label").changeColor();'>Change color!</a>   

要反方向推進事件,必須要使你的對象在JavaScript文檔上下文中可用。要對QWebPage的每一個 QWebFrame,調(diào)用addToJavaScriptWindowObject方法。這個方法允許你根據(jù)名字把一個對象添加到JavaScipt上下 文中。

  1. webView->page()->mainFrame()->addToJavaScriptWindowObject( "eventSource", new eventSource( this ) );  

要連接剛添加對象eventSource的信號,要加上一段JavaScript代碼,使用evaluateJavaScript方法 完成。下面的代碼將把eventSource對象的signalName信號連接到一個JavaScript函數(shù)destFunction。

  1. webView->page()->mainFrame()->evaluateJavaScript( "eventSource.signalName.connect(destFunction);" );  

如果你把一個對象添加到一個以標準瀏覽器查看的JavaScript頁面中,有一個信號需要知道。每一次JavaScript 內(nèi)容被清除,F(xiàn)rame都會釋放 javaScriptWindowObjectCleared 信號。為了使你的Qt對象一直可用,你需要連接這個信號,并且在這里調(diào)用 addToJavaScriptWindowObject函數(shù)。

#p#

三、使用客戶端存儲共享數(shù)據(jù)

 隨著HTML5,WEB標準日益靠近于桌面,同樣,桌面也開始集成WEB。這方面一個最大的變化就是客戶端存儲。這在客戶機上給了每一方(比如每一個頁 面)一個能利用SQL的數(shù)據(jù)庫引擎,可以緩存本地數(shù)據(jù),減少流量,使頁面能脫機使用。還可以用來存儲大量的結(jié)構(gòu)化的,可搜索的數(shù)據(jù)。

客戶端存儲可以在JavaScript中使用,從JavaScript代碼中搜索數(shù)據(jù)庫,然后從搜索結(jié)果中生成頁面。這要使用 openDatabase和transaction函數(shù)。

假設現(xiàn)在有個數(shù)據(jù)庫, 代碼如下所示:

  1. db = openDatabase("TestDb ", "1.0", "Client side storage test", 200000);  
  2. db.transaction(function(tx) {  
  3.       tx.executeSql("SELECT id, text FROM Texts", [], function(tx, result) {  
  4.           for (var i = 0; i < result.rows.length; ++i) {  
  5.               var row = result.rows.item(i);  
  6.                processText( row['id'], row['text'] );  
  7.          }  
  8.     },    function(tx, error) {  
  9.          alert('Failed to retrieve texts from the database - ' + error.message);  
  10.          return;  
  11.     });  
  12. });  

使用QtWebkit,你可以使用QtSql模塊訪問同一個數(shù)據(jù)庫。這在混合開發(fā)中是一個非常有用的特征。比如,你的應用中的web頁面在和本地部分共享 數(shù)據(jù)時,可以用同樣的機制來保存數(shù)據(jù)。

為了避免安全問題,客戶端的數(shù)據(jù)庫只能由具有正確權(quán)限的一方在JavaScript中訪問。本地的C++代碼也可以通過靜態(tài)的QWebSecurityOrigin::allOrigins 方法,或者通過QWebFrame::securityOrigin 來訪問所有安全對象。
  
通過databases方法,可以訪問一個 QWebDatabaew方法列表,每一個web數(shù)據(jù)庫對象有一個filename屬性,可以用來在本地代碼中訪問數(shù)據(jù)庫。

  1. QWebDatabase webdb = mySecurityOrigin.databases()[index];  
  2. QSqlDatabase sqldb = QSqlDatabase::addDatabase("QSQLITE", "webconnection");  
  3. sqldb.setDatabaseName(webdb.fileName());  
  4. if (sqldb.open()) {  
  5.     QStringList tables = sqldb.tables();  
  6. }  

在WEB和本地應用連接事件的能力,再加上共享數(shù)據(jù)的機制,更易于模糊WEB和桌面之間的界限。

四、WEB轉(zhuǎn)換

很多通過WEB得到的數(shù)據(jù)并不適合直接顯示。比如網(wǎng)絡新聞, 地理數(shù)據(jù),以及其它特定數(shù)據(jù)格式的應用。QT的網(wǎng)絡模塊可以以一種很簡單的方式下載這樣的數(shù)據(jù),然后解析數(shù)據(jù),把它轉(zhuǎn)換成能被自己的代碼處理的合適的格 式。也可以通過QtXmlPatterns模塊處理,當輸出格式是XML或者想在XHMTL網(wǎng)頁中顯示時,這樣更加方便。

我們通過一個小例子來大致了解一下這個有意思的部分。我們下載一個新聞源,用XSLT把它從XML轉(zhuǎn)換成XHTML,然后通過QWebPage把它顯示出 來。(圖略)

QNetworkAccessManager 類讓你很容易處理客戶端和WEB服務器之間的交互。它幫你處理諸如代理,保存設置,COOKIE以及SSL會話這些細節(jié)。總之,它不但讓你在象上傳下載這 些常見情況更加容易,還可以幫你處理登錄,認證這些復雜會話。
     
為了下載我們例子中的新聞源,我們所有要做的就是創(chuàng)建一個QNetworkAccessManager 然后調(diào)用它的get方法。結(jié)果通過 finished(QNetworkReply*) 信號返回。

  1. {  
  2. QNetworkAccessManager *manager = new QNetworkAccessManager( this );  
  3. connect( manager, SIGNAL(finished(QNetworkReply*)), this, SLOT(handleReply(QNetworkReply*)) );  
  4. connect( manager, SIGNAL(finished(QNetworkReply*)), m_progressBar, SLOT(hide()) );  
  5. QNetworkReply *reply = manager->get( QNetworkRequest( QUrl( feedUrl ) ) );  
  6. connect( reply, SIGNAL(downloadProgress(qint64, qint64)), this, SLOT(updateProgress(qint64,qint64)) );  
  7. }  

原文參見 http://www.qtsoftware.com/forms/whitepapers/reg-whitepaper-hybrid. (限于英文水平,只譯其大概)

小結(jié)::關于如何利用 QT 進行 web 與本地混合應用開發(fā)的內(nèi)容介紹完了,希望本文對你有所幫助!

責任編輯:zhaolei 來源: 網(wǎng)絡轉(zhuǎn)載
相關推薦

2010-09-15 12:15:23

NessusWEB應用安全掃描

2015-12-31 10:14:54

React.js開發(fā)Web應用

2011-06-13 14:29:40

Qt Designer

2013-01-15 10:20:56

Ubuntu Phon

2011-02-25 15:49:09

NecessitasQtAndroid

2014-04-09 14:02:21

混合云應用混合云

2013-09-13 12:58:07

原生應用Web應用混合應用

2010-11-17 12:59:52

2013-09-13 13:16:05

2013-08-29 09:53:04

HTML5MongoDB位置感知

2011-02-21 09:10:42

WebHTML 5JavaScript

2015-11-27 09:18:11

AngularJSWeb應用

2014-12-25 16:07:32

DHH混合移動應用Hybrid App

2011-03-25 11:06:46

2009-06-15 15:43:54

Stripes實現(xiàn)Ja

2024-05-28 08:11:44

SpringTensorFlow訓練

2009-06-23 16:52:16

JSFHibernateWeb應用

2009-07-27 09:23:24

2018-05-04 15:27:22

Spring Boo Web開發(fā)

2011-06-13 14:00:55

Qt Designer linux
點贊
收藏

51CTO技術棧公眾號

3d成人动漫网站| 亚洲欧洲国产日韩| 人九九综合九九宗合| 亚洲AV无码成人精品区明星换面| 欧美片第一页| 亚洲日本乱码在线观看| 国产青春久久久国产毛片| 久久亚洲精品石原莉奈| 国产精品精品国产一区二区| 亚洲精品999| 色一情一区二区三区| 制服丝袜在线播放| 久久午夜电影网| 成人免费网站在线观看| 五月天婷婷久久| 无需播放器亚洲| 亚洲欧洲日韩国产| 韩国三级在线播放| 亚洲四虎影院| 欧美日韩国产综合视频在线观看中文| 欧美精品一区在线发布| www.99视频| 日本欧美在线看| 97色在线观看| 欧美日韩免费一区二区| 日本一区二区免费高清| 亚洲国产小视频在线观看| 亚洲高清视频免费| av成人在线播放| 欧美色视频日本版| 欧美日韩不卡在线视频| 国产在线更新| 中文字幕中文字幕在线一区| 日本视频一区二区不卡| 无码精品在线观看| 成人网在线免费视频| 91九色视频导航| 涩涩视频在线观看| 日韩高清在线不卡| 日本精品视频在线播放| 日韩欧美亚洲一区二区三区| 欧美日本久久| 精品自在线视频| 裸体武打性艳史| 亚洲草久电影| 久久深夜福利免费观看| 91大神福利视频| 青草国产精品| 最近2019免费中文字幕视频三| 色天使在线视频| 国产乱人伦精品一区| 精品久久一二三区| 99免费观看视频| 风间由美一区二区av101| 欧美va在线播放| 第一页在线视频| 亚洲精品一二三**| 欧美videofree性高清杂交| 成人欧美精品一区二区| 97人人澡人人爽91综合色| 精品区一区二区| 中文字幕18页| 欧美调教在线| 国产香蕉97碰碰久久人人| 免费黄色片网站| 色婷婷色综合| 欧美乱妇40p| 国产在线视频卡一卡二| 一区二区91| 国产成人激情视频| ,一级淫片a看免费| 国产精品亚洲一区二区三区在线 | 国产稀缺真实呦乱在线| 一区在线视频| 日本亚洲欧洲色α| 亚洲午夜无码久久久久| 激情久久五月天| 成人黄色片视频网站| 天天操天天舔天天干| 久久精品亚洲国产奇米99| 先锋在线资源一区二区三区| 国内外激情在线| 午夜电影一区二区三区| 成人性视频欧美一区二区三区| 青青草国产一区二区三区| 日韩欧美成人午夜| 91成年人网站| 91精品电影| 国产91精品久久久久| 中文字幕网址在线| 国产91精品一区二区麻豆网站 | 欧美一区二区在线观看视频| 久久久蜜桃精品| 欧美日韩在线免费观看视频| 999精品网| 欧美午夜电影在线播放| 国产精品嫩草69影院| 精品国产91| 欧美国产第一页| 中文字幕在线网站| 成人国产精品免费观看动漫 | 国产在线观看黄| 亚洲精品高清在线| 15—17女人毛片| 好吊妞国产欧美日韩免费观看网站| 日韩精品免费看| 国产一区二区播放| 日本不卡免费在线视频| 国产高清在线一区二区| h视频网站在线观看| 亚洲风情在线资源站| 中文字幕22页| 教室别恋欧美无删减版| 久久久久国产视频| 国产女人18毛片水18精| 国产网站一区二区| 欧美大片在线播放| 日韩在线成人| 久久综合网hezyo| 日韩欧美一级大片| 91视频www| 日韩中字在线观看| 日韩精品三级| 久久精品国产欧美亚洲人人爽| 久久青青草原亚洲av无码麻豆| 国产盗摄一区二区三区| 亚洲自拍三区| 91大神在线观看线路一区| 精品无人区乱码1区2区3区在线| 欧美日韩偷拍视频| 国产在线国偷精品产拍免费yy | av在线日韩国产精品| 精品欧美激情精品一区| 久久精品aⅴ无码中文字字幕重口| 911精品美国片911久久久| 国产精品电影一区| 免费在线超碰| 色94色欧美sute亚洲线路一久| 欧产日产国产精品98| 一区在线播放| 国产一区国产精品| av电影院在线看| 亚洲成人网av| 亚欧视频在线观看| 26uuu久久天堂性欧美| 日韩少妇内射免费播放18禁裸乳| 精品一区二区男人吃奶| 91精品成人久久| 手机亚洲第一页| 一本色道a无线码一区v| 亚洲自拍偷拍一区二区| 小嫩嫩精品导航| 免费亚洲精品视频| japanese23hdxxxx日韩| 在线免费看av不卡| 国产精品高潮呻吟av| 亚洲欧美日韩综合aⅴ视频| 樱花草www在线| 欧美三区视频| 激情一区二区三区| 国模冰冰炮一区二区| 在线观看日韩视频| 国产美女三级无套内谢| 亚洲综合激情小说| 五月婷婷综合在线观看| 日韩高清中文字幕一区| 中文字幕免费高| 国产66精品| 欧美在线视频一区| av大片在线播放| 这里只有精品99re| 久久精品国产亚洲av高清色欲| av在线综合网| 久久久国产欧美| 91精品国产自产拍在线观看蜜| 91一区二区三区| 69av成人| 色噜噜久久综合伊人一本| 国产高清视频免费观看| 亚洲国产精品一区二区久久| 成人在线一级片| 国产综合色视频| 日本在线xxx| 日韩一区自拍| 国产一区视频观看| 国产激情欧美| 久久久噜久噜久久综合| 黄上黄在线观看| 日韩欧美亚洲国产另类| 久久久久久久久久久久久av| 国产精品成人一区二区三区夜夜夜| 一个人看的视频www| 香蕉久久a毛片| 国内外成人激情免费视频| 色综合www| 91精品黄色| 456成人影院在线观看| 欧美日韩成人在线视频| 高清av电影在线观看| 亚洲福利视频网站| 国产麻豆91视频| 91豆麻精品91久久久久久| 99视频只有精品| 国产精品三级av| 精品黑人一区二区三区观看时间| 国产在线国偷精品免费看| 午夜精品久久久内射近拍高清| 亚洲天天影视网| 日韩欧美精品在线不卡| 红杏aⅴ成人免费视频| 91免费高清视频| 最新日韩一区| 日韩av片免费在线观看| 交100部在线观看| 美女av一区二区三区 | 欧美日韩高清区| eeuss影院www在线播放| 日韩va亚洲va欧洲va国产| 91丨porny丨在线中文 | 91麻豆精品91久久久久同性| 亚洲自拍一区在线观看| 亚洲不卡在线观看| 波多野结衣亚洲色图| 中文字幕一区二区日韩精品绯色| 这里只有久久精品| 久久综合久久综合亚洲| www.日本高清| 成人白浆超碰人人人人| 2018国产精品| 高清免费成人av| 青娱乐国产精品视频| 午夜免费播放观看在线视频| 在线播放一区| 一区二区三区四区国产| 免费成人结看片| 国产亚洲一区在线播放| 欧美成人精品一级| 国产一区红桃视频| 黄色欧美视频| 国产精品美女www| 成人在线黄色| 国产精品久久久久高潮| 日韩精品三区| 日韩免费av片在线观看| 中文字幕在线看片| 8090成年在线看片午夜| 国产资源在线观看入口av| 国内精品模特av私拍在线观看| 欧美人与牲禽动交com| 欧美成人三级视频网站| 97caopor国产在线视频| 久久999免费视频| 里番在线播放| 国内偷自视频区视频综合 | 亚洲精品3区| 欧美欧美一区二区| 精品国产午夜| 亚洲一二三区在线| 五月天激情综合网| 精品国产一区二区三区无码| 日本v片在线免费观看| 亚洲永久免费| 成人免费毛片网| 免费在线成人| 午夜宅男在线视频| 国产精品夜夜嗨| 美女伦理水蜜桃4| 成人黄色综合网站| 中文字幕免费高清| 国产精品久久久久久久久免费桃花| 日本爱爱小视频| 一二三区精品福利视频| 国产 欧美 日韩 在线| 日本韩国一区二区| 亚洲综合精品国产一区二区三区| 6080午夜不卡| 日韩中文字幕免费观看| 亚洲裸体xxxx| 日本中文字幕在线看| 欧美精品videos| 欧美18av| 亚洲最大福利视频网站| 青青视频一区二区| 午夜久久资源| 五月久久久综合一区二区小说| 欧美视频在线观看视频| 久久综合激情| 人妻巨大乳一二三区| 91亚洲国产成人精品一区二三| www色com| 亚洲第一av色| 在线不卡免费视频| 精品捆绑美女sm三区| caoporn国产精品免费视频| 久操成人在线视频| 成人日韩av| 国内视频一区| 亚洲不卡av不卡一区二区| 日韩视频第二页| 国产成人亚洲综合a∨猫咪| 成年人网站免费在线观看 | 中文字幕一区二区三区在线乱码 | 天天操综合520| 正在播放久久| 久久蜜桃精品| 美女网站视频在线观看| 国产精品美女视频| 黄色片中文字幕| 日韩精品一区二区三区在线播放| 波多野结衣一区二区| 97视频免费看| 日韩视频在线直播| 色涩成人影视在线播放| 一本久道久久综合狠狠爱| 91香蕉视频在线观看视频| 久久精品亚洲精品国产欧美| 日本学生初尝黑人巨免费视频| 欧美卡1卡2卡| www日韩tube| 日本视频久久久| 国产精品极品在线观看| 国产成人亚洲综合无码| 久久 天天综合| 国产又粗又猛又爽又黄av| 精品免费在线视频| 日本国产在线观看| 欧美国产乱视频| 视频一区视频二区欧美| 波多野结衣三级在线| 秋霞影院一区二区| 婷婷色一区二区三区| 欧美日韩免费看| 日本高清视频免费观看| 久久久噜噜噜久久| 国产乱论精品| 自拍日韩亚洲一区在线| 成人毛片在线观看| 久久久久亚洲AV| 欧美va亚洲va香蕉在线| 免费网站在线观看人| 97人人模人人爽人人少妇| 亚洲乱码精品| 免费高清视频在线观看| 亚洲人成伊人成综合网小说| 在线免费看毛片| 精品国产拍在线观看| 天堂久久一区| www.-级毛片线天内射视视| 激情六月婷婷综合| 欧美亚洲日本在线| 欧美大黄免费观看| 福利成人导航| 久久狠狠久久综合桃花| 亚洲综合精品| 黄色三级生活片| 欧美日韩一区三区| av网站免费在线观看| 成人av资源网| 99国产精品久久久久久久 | 中文字幕一区二区三区四区不卡| 亚洲性在线观看| 久久中文字幕国产| 在线精品自拍| 午夜精品久久久内射近拍高清| 国产免费成人在线视频| 97人妻精品一区二区三区| 久精品免费视频| 日韩伦理一区二区三区| 亚洲免费av一区二区三区| 国产精品久久精品日日| 国产高潮流白浆喷水视频| 久久人人看视频| 九色精品91| 午夜免费福利网站| 亚洲成人av电影在线| 精品福利视频导航大全| 国产在线拍偷自揄拍精品| 欧美日韩国产精品一区二区亚洲| 欧美熟妇精品黑人巨大一二三区| 欧亚洲嫩模精品一区三区| 超碰在线免费播放| 久久国产手机看片| 精品一区二区在线观看| 日韩欧美大片在线观看| 国产亚洲视频在线| 伊人www22综合色| 99视频在线免费| 亚洲一线二线三线久久久| 男女网站在线观看| 69174成人网| 老牛影视一区二区三区| 超碰手机在线观看| 亚洲欧美国产高清va在线播| 国产精品欧美一区二区三区不卡| 日韩在线综合网| 日韩毛片精品高清免费| 免费人成在线观看网站| 99久久国产免费免费| 日本免费新一区视频| 国产在线观看免费视频今夜|