iOS開發(fā) : UIWebView加載網(wǎng)頁以及與JavaScript交互

使用UIWebView可以實現(xiàn)一個Web瀏覽器,可以時間加載靜態(tài)HTML、動態(tài)URL地址拙毫,也可以實現(xiàn)網(wǎng)頁導航,以及調用JavaScript等峭跳。

一袍患、加載一個動態(tài)URL地址的步驟:

// 1. 實例化一個UIWebView
UIWebView *webView = [[UIWebView alloc] initWithFrame:self.view.bounds];

// 2. 獲得NSURLRequest對象
NSString *str = @"http://www.baidu.com";
NSURL *url = [NSURL URLWithString:str];
NSURLRequest *request = [NSURLRequest requestWithURL:url];

// 3. 調用UIWebView的loadRequest方法加載網(wǎng)頁內(nèi)容
[webView loadRequest:request];

二、使用UIWebView加載靜態(tài)的HTML頁面

// 1. 實例化UIWebView
UIWebView *webView = [[UIWebView alloc] initWithFrame:self.view.bounds];

// 2. 以字符串的形式保存HTML代碼
NSString *str = @"Hello<b>你好</b>....<a href = http://www.baidu.com>百度一下</a>";

// 3. 使用UIWebView的loadHTMLString:baseURL方法加載頁面
[webView loadHTMLString:str baseURL:nil];

// 4. 將webView添加到控制器的view上
[self.view addSubview:webView];

三滞欠、可以為UIWebView設置代理來監(jiān)控UIWebView的加載過程肆良。下面代碼演示了如何在顯示網(wǎng)頁之前顯示加載進度標識

  1. 遵守UIWebViewDelegate協(xié)議
@interface TestViewController () <UIWebViewDelegate>
@property (nonatomic,weak) UIWebView *webView;
@property (nonatomic,weak) UIActivityIndicatorView *aiv;
@end
  1. 實例化UIWebView和UIActivityIndicatorView
// 實例化UIWebView
UIWebView *webView = [[UIWebView alloc] initWithFrame:self.view.bounds];

// 實例化UIActivityIndicatorView
UIActivityIndicatorView *aiv = [[UIActivityIndicatorView alloc] initWithFrame:CGRectMake(50, 100, 100, 100)];

// 設置UIWebView的代理
webView.delegate = self;

// 設置UIActivityIndicatorView的樣式
aiv.activityIndicatorViewStyle = UIActivityIndicatorViewStyleGray;

//  設置UIActivityIndicatorView的中心點位置與UIWebView相同
aiv.center = webView.center;
self.webView = webView;
self.aiv = aiv;
  1. 實例化NSURLRequest對象,并加載網(wǎng)頁
// 設置要訪問的網(wǎng)絡URL
NSString *str = @"http://www.baidu.com";

// 實例化NSURL
NSURL *url = [NSURL URLWithString:str];

// 實例化NSURLRequest
NSURLRequest *request = [NSURLRequest requestWithURL:url];

// 加載網(wǎng)頁
[webView loadRequest:request];

// 添加UIActivityIndicatorView到UIWebView
[webView addSubview:aiv];
[self.view addSubview:webView];
  1. 實現(xiàn)協(xié)議方法
// 開始加載網(wǎng)頁時會來到該方法
- (void)webViewDidStartLoad:(UIWebView *)webView
{
// 開始執(zhí)行動畫
[self.aiv startAnimating];
self.aiv.hidden = NO;
}

// 網(wǎng)頁已經(jīng)加載完成時會來到該方法
- (void)webViewDidFinishLoad:(UIWebView *)webView
{
// 停止動畫
[self.aiv stopAnimating];
self.aiv.hidden = YES;
}

四夭谤、UIWebView和網(wǎng)頁的JavaScript之間可以相互通信。下面代碼在界面添加一個按鈕和UIWebView颊乘,點擊按鈕調用JavaScript代碼中的方法彈出提示框

  1. 在界面添加一個按鈕和UIWebView
//  創(chuàng)建UIWebView對象
UIWebView *webView = [[UIWebView alloc] initWithFrame:self.view.bounds];

// 創(chuàng)建一個按鈕
UIButton *btn = [[UIButton alloc] initWithFrame:CGRectMake(120, 80, 60, 40)];
[btn setTitle:@"testBtn" forState:UIControlStateNormal];
[btn setBackgroundColor:[UIColor greenColor]];
[btn setTitleColor:[UIColor blackColor] forState:UIControlStateNormal];
[btn addTarget:self action:@selector(clickBtn) forControlEvents:UIControlEventTouchUpInside];

// 將按鈕和UIWebView添加到控制器的view
[self.view addSubview:webView];
[self.view addSubview:btn];
  1. 動態(tài)拼接HTML和JavaScript乏悄,并使用UIWebView加載頁面
NSMutableString *mStr = [NSMutableString stringWithCapacity:20];

[mStr appendString:@"<html>"];
[mStr appendString:@"<head>"];
[mStr appendString:@"<script>"];
[mStr appendString:@"function showAlert() {alert('Hello')}"];
[mStr appendString:@"</script>"];
[mStr appendString:@"</head>"];
[mStr appendString:@"<body>"];
[mStr appendString:@"Test JavaScript"];
[mStr appendString:@"<b>"];
[mStr appendString:@"nihao"];
[mStr appendString:@"</b>"];
[mStr appendString:@"</body>"];
[mStr appendString:@"</html>"];

// 加載頁面
[webView loadHTMLString:mStr baseURL:nil];
  1. 在按鈕的點擊事件方法中加載JavaScript函數(shù)
- (void)clickBtn
{
[self.webView stringByEvaluatingJavaScriptFromString:@"showAlert()"];
}

如果要添加index.html文件恳不,先將index.html文件導入項目,然后獲取文件路徑规求,利用stringWithContentsOfFile獲取內(nèi)容展示頁面

NSString *filePath = [[NSBundle mainBundle] pathForResource:@"index" ofType:@"html"];
[self.webView loadHTMLString:[NSString stringWithContentsOfFile:filePath encoding:NSUTF8StringEncoding error:nil] baseURL:nil];

五. UIWebView界面實現(xiàn)前進卵惦、后退和刷新功能

// 前進
[self.webView goForward];

// 后退
[self.webView goBack];

// 刷新
[self.webView reload];
?著作權歸作者所有,轉載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市冕茅,隨后出現(xiàn)的幾起案子蛹找,更是在濱河造成了極大的恐慌哨坪,老刑警劉巖,帶你破解...
    沈念sama閱讀 222,000評論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件届慈,死亡現(xiàn)場離奇詭異忿偷,居然都是意外死亡,警方通過查閱死者的電腦和手機鲤桥,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,745評論 3 399
  • 文/潘曉璐 我一進店門茶凳,熙熙樓的掌柜王于貴愁眉苦臉地迎上來播揪,“玉大人,你說我怎么就攤上這事猪狈”缒眨” “怎么了?”我有些...
    開封第一講書人閱讀 168,561評論 0 360
  • 文/不壞的土叔 我叫張陵状共,是天一觀的道長谁帕。 經(jīng)常有香客問我,道長匈挖,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 59,782評論 1 298
  • 正文 為了忘掉前任舶吗,我火速辦了婚禮择膝,結果婚禮上,老公的妹妹穿的比我還像新娘肴捉。我一直安慰自己,他們只是感情好傲隶,可當我...
    茶點故事閱讀 68,798評論 6 397
  • 文/花漫 我一把揭開白布窃页。 她就那樣靜靜地躺著,像睡著了一般乒省。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上袖扛,一...
    開封第一講書人閱讀 52,394評論 1 310
  • 那天攻锰,我揣著相機與錄音晾嘶,去河邊找鬼垒迂。 笑死,一個胖子當著我的面吹牛机断,可吹牛的內(nèi)容都是我干的绣夺。 我是一名探鬼主播,決...
    沈念sama閱讀 40,952評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼奋蔚,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了泊碑?” 一聲冷哼從身側響起毯欣,我...
    開封第一講書人閱讀 39,852評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎腹忽,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體砚作,經(jīng)...
    沈念sama閱讀 46,409評論 1 318
  • 正文 獨居荒郊野嶺守林人離奇死亡偎巢,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,483評論 3 341
  • 正文 我和宋清朗相戀三年兼耀,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片瘤运。...
    茶點故事閱讀 40,615評論 1 352
  • 序言:一個原本活蹦亂跳的男人離奇死亡拯坟,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出郁季,到底是詐尸還是另有隱情钱磅,我是刑警寧澤似枕,帶...
    沈念sama閱讀 36,303評論 5 350
  • 正文 年R本政府宣布,位于F島的核電站褪迟,受9級特大地震影響,放射性物質發(fā)生泄漏味赃。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,979評論 3 334
  • 文/蒙蒙 一心俗、第九天 我趴在偏房一處隱蔽的房頂上張望另凌。 院中可真熱鬧,春花似錦吠谢、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,470評論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至楚午,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間矾柜,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,571評論 1 272
  • 我被黑心中介騙來泰國打工里覆, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留缆瓣,地道東北人。 一個月前我還...
    沈念sama閱讀 49,041評論 3 377
  • 正文 我出身青樓隧甚,卻偏偏與公主長得像,于是被迫代替她去往敵國和親戚扳。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 45,630評論 2 359

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