iOS开发-UIWebView加载本地和网络数据

十度 IOS 2015年12月01日 收藏

UIWebView是内置的浏览器控件,可以用它来浏览网页、打开文档,关于浏览网页榜样可以参考UC,手机必备浏览器,至于文档浏览的手机很多图书阅读软件,UIWebView是一个混合体,具体的功能控件内置的,实现一些基本的功能。UIWebView可以查看Html网页,pdf文件,docx文件,txt文件文件,系统自带的Safari就是UIWebView实现的。

基础布局

页面布局很简单就是一个文本框,一个按钮,一个UIWebView,页面布局如下:

如果想简单一点的话,其实用UIWebView也行,不过需要先准备一些文本数据,具体如下:

数据加载

①直接拼接Html,用UIWebView显示,viewDidLoad中添加代码:

  1. //直接加载Html字符串
  2. NSString *htmlStr=@"<html><head><title>Html加载</title></head><body>HtmlDemo-FlyElephant</body></html>";
  3. [self.webView loadHTMLString:htmlStr baseURL:nil];

 

 

②加载本地的Html网页,Book.html中代码:

  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <meta charset="UTF-8">
  5. <title>书籍</title>
  6. </head>
  7. <body>
  8. 少年维特之烦恼-歌德
  9. </body>
  10. </html>

viewDidLoad代码:

  1. NSString *filePath = [[NSBundle mainBundle]pathForResource:@"Book" ofType:@"html"];
  2. NSString *htmlString = [NSString stringWithContentsOfFile:filePath encoding:NSUTF8StringEncoding error:nil];
  3. [self.webView loadHTMLString:htmlString baseURL:[NSURL URLWithString:filePath]];

③加载本地的pdf文件,viewDidLoad代码:

  1. NSURL *url = [[NSBundle mainBundle]URLForResource:@"Book.pdf" withExtension:nil];
  2. NSURLRequest *request = [NSURLRequest requestWithURL:url];
  3. [self.webView loadRequest:request];

  

加载pdf的第二种方式:

  1. NSString *path = [[NSBundle mainBundle]pathForResource:@"Book.pdf" ofType:nil];
  2. //以二进制的形式加载数据
  3. NSData *data = [NSData dataWithContentsOfFile:path];
  4. [self.webView loadData:data MIMEType:@"application/pdf" textEncodingName:@"UTF-8" baseURL:nil];

④加载本地txt文件,viewDidLoad代码如下:

  1. //加载txt
  2. NSURL *url = [[NSBundle mainBundle]URLForResource:@"Book.txt" withExtension:nil];
  3. //设置Url
  4. [self.webView loadRequest:[NSURLRequest requestWithURL:url]];

  

⑤加载Word,viewDidLoad代码如下:

  1. //加载Word
  2. NSURL *url = [[NSBundle mainBundle]URLForResource:@"Book.docx" withExtension:nil];
  3. //设置加载Url
  4. [self.webView loadRequest:[NSURLRequest requestWithURL:url]];

  

⑥加载网络数据,跳转按钮事件中实现如下:

  1. NSURLRequest *request =[NSURLRequest requestWithURL:[NSURL URLWithString:self.urlText.text]];
  2. [self.webView loadRequest:request];

  

⑦设置委托,在不同的阶段处理数据,实现UIWebViewDelegate,设置自己本身为委托对象;

  1. [self.webView setDelegate:self];

常用的三个方法:

  1. //加载开始
  2. - (void)webViewDidStartLoad:(UIWebView *)webView{
  3. NSLog(@"加载开始的时候的方法调用");
  4. }
  5. //加载完成
  6. -(void)webViewDidFinishLoad:(UIWebView *)webView{
  7. NSLog(@"加载完成的时候电脑方法调用");
  8. }
  9. //加载出错
  10. - (void)webView:(UIWebView *)webView didFailLoadWithError:(NSError *)error{
  11. NSLog(@"加载出错的时候的调用");
  12. }