iOS UIWebView的使用

????? 現(xiàn)在對(duì)于 混合式 移動(dòng)端開(kāi)發(fā)越來(lái)越流行构韵,因?yàn)殚_(kāi)發(fā)成本上虫啥、速度上都比傳統(tǒng)的APP開(kāi)發(fā)要好显拜,混合式開(kāi)發(fā)是傳統(tǒng)模式與PC網(wǎng)頁(yè)端相結(jié)合的模式。那么提到了APP的混合模式開(kāi)發(fā)瓤介,在Android開(kāi)發(fā)中有WebView作為混合模式開(kāi)發(fā)的橋梁吕喘,當(dāng)然在IOS中也同樣有一個(gè) UIWebView組件來(lái)作為混合模式開(kāi)發(fā)的橋梁,那么下面就對(duì)UIWebView的一些基本知識(shí)詳解一下刑桑。

一氯质、UIWebView的基礎(chǔ)使用

1、創(chuàng)建UIWebView:

CGRect bouds = [[UIScreen manScreen]applicationFrame];

UIWebView* webView = [[UIWebView alloc]initWithFrame:bounds];

2祠斧、設(shè)置屬性:

webView.scalespageToFit = YES;//自動(dòng)對(duì)頁(yè)面進(jìn)行縮放以適應(yīng)屏幕

webView.detectsPhoneNumbers = YES;//自動(dòng)檢測(cè)網(wǎng)頁(yè)上的電話號(hào)碼病梢,單擊可以撥打

3、顯示網(wǎng)頁(yè)視圖UIWebView:

[self.view addSubview:webView];

4梁肿、加載內(nèi)容

NSURL* url = [NSURL URLWithString:@"http://www.baidu.com"];//創(chuàng)建URL

NSURLRequest* request = [NSURLRequest requestWithURL:url];//創(chuàng)建NSURLRequest

[webView loadRequest:request];//加載

也可以加載一個(gè)本地資源:

NSURL* url = [NSURL fileURLWithPath:filePath];//創(chuàng)建URL

NSURLRequest* request = [NSURLRequest requestWithURL:url];//創(chuàng)建NSURLRequest

[webView loadRequest:request];//加載

UIWebView 還支持將一個(gè)NSString對(duì)象作為源來(lái)加載蜓陌。你可以為其提供一個(gè)基礎(chǔ)URL,來(lái)指導(dǎo)UIWebView對(duì)象如何跟隨鏈接和加載遠(yuǎn)程資源:

[webView loadHTMLString:myHTML baseURL:[NSURL URLWithString:@"http://baidu.com"]];

5吩蔑、導(dǎo)航

UIWebView類內(nèi)部會(huì)管理瀏覽器的導(dǎo)航動(dòng)作钮热,通過(guò)goForward和goBack方法你可以控制前進(jìn)與后退動(dòng)作:

[webView goBack];

[webView goForward];

[webView reload];//重載

[webView stopLoading];//取消載入內(nèi)容

6、UIWebViewDelegate委托代理

UIWebView支持一組委托方法烛芬,這些方法將在特定時(shí)間得到通知隧期。要使用這些方法,必須先設(shè)定webView的委托:

webView.delegate = self;

下面每個(gè)委托方法的第一個(gè)參數(shù)都是指向一個(gè)UIwebview的指針赘娄,因此你可以將一個(gè)委托用于多個(gè)網(wǎng)頁(yè)視圖仆潮。

-(BOOL)webView:(UIWebView*)webView shouldStartLoadWithRequest:(NSURLRequest*) reuqest navigationType: (UIWebViewNavigationType)navigationType;//當(dāng)網(wǎng)頁(yè)視圖被指示載入內(nèi)容而得到通知。應(yīng)當(dāng)返回YES遣臼,這樣會(huì)進(jìn)行加載性置。通過(guò)導(dǎo)航類型參數(shù)可以得到請(qǐng)求發(fā)起的原因,可以是以下任意值:

UIWebViewNavigationTypeLinkClicked

UIWebViewNavigationTypeFormSubmitted

UIWebViewNavigationTypeBackForward

UIWebViewNavigationTypeReload

UIWebViewNavigationTypeFormResubmitted

UIWebViewNavigationTypeOther

UIWebView控件加載網(wǎng)頁(yè)的監(jiān)聽(tīng)函數(shù)方法:

-(void)webViewDidStartLoad:(UIWebView*)webView ;//當(dāng)網(wǎng)頁(yè)視圖已經(jīng)開(kāi)始加載一個(gè)請(qǐng)求后揍堰,得到通知鹏浅。

-(void)webViewDidFinishLoad:(UIWebView*)webView ;//當(dāng)網(wǎng)頁(yè)視圖結(jié)束加載一個(gè)請(qǐng)求之后嗅义,得到通知。

-(void)webView:(UIWebView*)webView DidFailLoadWithError:(NSError*)error;//當(dāng)在請(qǐng)求加載中發(fā)生錯(cuò)誤時(shí)隐砸,得到通知之碗。會(huì)提供一個(gè)NSSError對(duì)象,以標(biāo)識(shí)所發(fā)生錯(cuò)誤類型季希。

以上是IOS中UIWebView的基礎(chǔ)使用要點(diǎn)詳解褪那,接下來(lái)一些UIWebView的常用注意點(diǎn)。

二式塌、IOS中UIWebView常用注意點(diǎn):

1博敬、與UIWebView進(jìn)行交互,調(diào)用web頁(yè)面中的需要傳參的函數(shù)時(shí)珊搀,參數(shù)需要帶單引號(hào)冶忱,或者雙引號(hào)(雙引號(hào)需要進(jìn)行轉(zhuǎn)義在轉(zhuǎn)義字符前加\),在傳遞json字符串時(shí)不需要加單引號(hào)或雙引號(hào):

-(void)webViewDidFinishLoad:(UIWebView *)webView

{

NSString *sendJsStr=[NSString stringWithFormat:@"openFile(\"%@\")",jsDocPathStr];

[webView stringByEvaluatingJavaScriptFromString:sendJsStr];

}

2、在該代理方法中判斷與webView的交互境析,可通過(guò)html里定義的協(xié)議實(shí)現(xiàn):

- (BOOL)webView:(UIWebView*)webView

shouldStartLoadWithRequest:(NSURLRequest*)request

navigationType:(UIWebViewNavigationType)navigationType

3囚枪、只有在webView加載完畢之后在能夠調(diào)用對(duì)應(yīng)頁(yè)面中的js方法。(對(duì)應(yīng)方法如第1條).

4劳淆、為webView添加背景圖片:

approvalWebView.backgroundColor=[UIColor clearColor];

approvalWebView.opaque=NO;//這句話很重要链沼,webView是否是不透明的,no為透明 在webView下添加個(gè)imageView展示圖片就可以了

5沛鸵、獲取webView頁(yè)面內(nèi)容信息:

NSString *docStr=[webView stringByEvaluatingJavaScriptFromString:@"document.documentElement.textContent"];//獲取web頁(yè)面內(nèi)容信息括勺,此處獲取的是個(gè)json字符串

SBJsonParser *parserJson=[[[SBJsonParser alloc]init]autorelease];

NSDictionary *contentDic=[parserJson objectWithString:docStr];//將json字符串轉(zhuǎn)化為字典

6、 加載本地文件的方法:

//第一種方法:

NSString* path = [[NSBundle mainBundle] pathForResource:name ofType:@"html" inDirectory:@"mobile"];//mobile是根目錄曲掰,name是文件名稱疾捍,html是文件類型

[webView loadRequest:[NSURLRequest requestWithURL:[NSURL fileURLWithPath:path]]]; //加載本地文件

//第二種方法:

NSString *resourcePath = [[NSBundle mainBundle] resourcePath];

NSString *filePath = [resourcePath stringByAppendingPathComponent:@"mobile.html"];

NSString *htmlstring=[[NSString alloc] initWithContentsOfFile:filePath encoding:NSUTF8StringEncoding error:nil];

[uiwebview loadHTMLString:htmlstring baseURL:[NSURL fileURLWithPath:[[NSBundle mainBundle] bundlePath]]];

7、將文件下載到本地址然后再用webView打開(kāi):

NSString *resourceDocPath = [[NSString alloc] initWithString:[[[[NSBundle mainBundle] resourcePath]stringByDeletingLastPathComponent] stringByAppendingPathComponent:@"Documents"]];

self.filePath = [resourceDocPath stringByAppendingPathComponent:[NSString stringWithFormat:@"maydoc%@",docType]];

NSData *attachmentData = [[NSData alloc] initWithContentsOfURL:[NSURL URLWithString:theUrl]];

[attachmentData writeToFile:filePath atomically:YES];

NSURL *url = [NSURL fileURLWithPath:filePath];

NSURLRequest *requestObj = [NSURLRequest requestWithURL:url];

[attachmentWebView loadRequest:requestObj];

//刪除指定目錄下的文件

NSFileManager *magngerDoc=[NSFileManager defaultManager];

[magngerDoc removeItemAtPath:filePath error:nil];

8栏妖、處理webView展示txt文檔亂碼問(wèn)題:

if ([theType isEqualToString:@".txt"])

{

//txt分帶編碼和不帶編碼兩種乱豆,帶編碼的如UTF-8格式txt,不帶編碼的如ANSI格式txt

//不帶的吊趾,可以依次嘗試GBK和GB18030編碼

NSString* aStr = [[NSString alloc] initWithData:attachmentData encoding:NSUTF8StringEncoding];

if (!aStr)

{

//用GBK進(jìn)行編碼

aStr=[[NSString alloc] initWithData:attachmentData encoding:0x80000632];

}

if (!aStr)

{

//用GBK編碼不行,再用GB18030編碼

aStr=[[NSString alloc] initWithData:attachmentData encoding:0x80000631];

}

//通過(guò)html語(yǔ)言進(jìn)行排版

NSString* responseStr = [NSString stringWithFormat:

@""

""

""

""

""

"

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末宛裕,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子论泛,更是在濱河造成了極大的恐慌揩尸,老刑警劉巖,帶你破解...
    沈念sama閱讀 219,490評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件屁奏,死亡現(xiàn)場(chǎng)離奇詭異岩榆,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,581評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門朗恳,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)湿颅,“玉大人载绿,你說(shuō)我怎么就攤上這事粥诫。” “怎么了崭庸?”我有些...
    開(kāi)封第一講書人閱讀 165,830評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵怀浆,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我怕享,道長(zhǎng)执赡,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書人閱讀 58,957評(píng)論 1 295
  • 正文 為了忘掉前任函筋,我火速辦了婚禮沙合,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘跌帐。我一直安慰自己首懈,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,974評(píng)論 6 393
  • 文/花漫 我一把揭開(kāi)白布谨敛。 她就那樣靜靜地躺著究履,像睡著了一般。 火紅的嫁衣襯著肌膚如雪脸狸。 梳的紋絲不亂的頭發(fā)上最仑,一...
    開(kāi)封第一講書人閱讀 51,754評(píng)論 1 307
  • 那天,我揣著相機(jī)與錄音炊甲,去河邊找鬼泥彤。 笑死,一個(gè)胖子當(dāng)著我的面吹牛卿啡,可吹牛的內(nèi)容都是我干的吟吝。 我是一名探鬼主播,決...
    沈念sama閱讀 40,464評(píng)論 3 420
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼牵囤,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼爸黄!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起揭鳞,我...
    開(kāi)封第一講書人閱讀 39,357評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤炕贵,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后野崇,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體称开,經(jīng)...
    沈念sama閱讀 45,847評(píng)論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,995評(píng)論 3 338
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了鳖轰。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片清酥。...
    茶點(diǎn)故事閱讀 40,137評(píng)論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖蕴侣,靈堂內(nèi)的尸體忽然破棺而出焰轻,到底是詐尸還是另有隱情,我是刑警寧澤昆雀,帶...
    沈念sama閱讀 35,819評(píng)論 5 346
  • 正文 年R本政府宣布辱志,位于F島的核電站,受9級(jí)特大地震影響狞膘,放射性物質(zhì)發(fā)生泄漏揩懒。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,482評(píng)論 3 331
  • 文/蒙蒙 一挽封、第九天 我趴在偏房一處隱蔽的房頂上張望已球。 院中可真熱鬧,春花似錦辅愿、人聲如沸智亮。這莊子的主人今日做“春日...
    開(kāi)封第一講書人閱讀 32,023評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)鸽素。三九已至,卻和暖如春亦鳞,著一層夾襖步出監(jiān)牢的瞬間馍忽,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書人閱讀 33,149評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工燕差, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留遭笋,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,409評(píng)論 3 373
  • 正文 我出身青樓徒探,卻偏偏與公主長(zhǎng)得像瓦呼,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子测暗,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,086評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容

  • IOS之UIWebView的使用 剛接觸IOS開(kāi)發(fā)1年多央串,現(xiàn)在對(duì)于 混合式 移動(dòng)端開(kāi)發(fā)越來(lái)越流行,因?yàn)殚_(kāi)發(fā)成本上碗啄、...
    學(xué)無(wú)止境666閱讀 45,790評(píng)論 5 53
  • OS之UIWebView的使用 剛接觸IOS開(kāi)發(fā)1年多质和,現(xiàn)在對(duì)于 混合式 移動(dòng)端開(kāi)發(fā)越來(lái)越流行,因?yàn)殚_(kāi)發(fā)成本上稚字、速...
    知之未道閱讀 1,659評(píng)論 0 4
  • iOS開(kāi)發(fā)系列--網(wǎng)絡(luò)開(kāi)發(fā) 概覽 大部分應(yīng)用程序都或多或少會(huì)牽扯到網(wǎng)絡(luò)開(kāi)發(fā)饲宿,例如說(shuō)新浪微博厦酬、微信等,這些應(yīng)用本身可...
    lichengjin閱讀 3,666評(píng)論 2 7
  • 一瘫想、UIWebView的基本語(yǔ)法 1仗阅、創(chuàng)建UIWebView: CGRect bouds = [[UIScreen...
    成語(yǔ)筆記閱讀 314評(píng)論 0 0
  • 1 / 我愛(ài)你 男女之間沒(méi)有純潔的友情,若有国夜,也是一方打死不說(shuō)减噪,一方打死不認(rèn)。 你不愛(ài)我沒(méi)關(guān)系支竹,我...
    文藝女青年的思想救贖閱讀 258評(píng)論 1 3