您的位置:首页 > 移动开发

iOS UIWebView 加载网页、文件、 html

2016-04-11 16:47 585 查看
UIWebView 是用来加载加载网页数据的一个框。UIWebView可以用来加载pdf word doc 等等文件

生成webview 有两种方法:

1、通过storyboard 拖拽

2、通过alloc init 来初始化

创建webview,下列文本中

_webView.dataDetectorTypes = UIDataDetectorTypeAll;


是识别webview中的类型,例如 当webview中有电话号码,点击号码就能直接打电话

- (UIWebView *)webView
{
if (!_webView) {
_webView = [[UIWebView alloc] initWithFrame:self.view.bounds];
_webView.dataDetectorTypes = UIDataDetectorTypeAll;
}
return _webView;
}


1.加载网页

// 让浏览器加载指定的字符串,使用m.baidu.com进行搜索
- (void)loadString:(NSString *)str
{
// 1. URL 定位资源,需要资源的地址
NSString *urlStr = str;
if (![str hasPrefix:@"http://"]) {
urlStr = [NSString stringWithFormat:@"http://m.baidu.com/s?word=%@", str];
}

NSURL *url = [NSURL URLWithString:urlStr];

// 2. 把URL告诉给服务器,请求,从m.baidu.com请求数据
NSURLRequest *request = [NSURLRequest requestWithURL:url];

// 3. 发送请求给服务器
[self.webView loadRequest:request];
}


2.加载html

// HTML是网页的设计语言
// <>表示标记</>
// 应用场景:截取网页中的某一部分显示
// 例如:网页的完整内容中包含广告!加载完成页面之后,把广告部分的HTML删除,然后再加载
// 被很多新闻类的应用程序使用
[self.webView loadHTMLString:@"<p>Hello</p>" baseURL:nil];


3.加载本地文件

#pragma mark - 加载文件
- (void)loadFile
{
// 应用场景:加载从服务器上下载的文件,例如pdf,或者word,图片等等文件
NSURL *fileURL = [[NSBundle mainBundle] URLForResource:@"关于.txt" withExtension:nil];

NSURLRequest *request = [NSURLRequest requestWithURL:fileURL];

[self.webView loadRequest:request];
}


3.以二级制的方式加载本地文件

#pragma 以二进制数据的形式加载文件
- (void)loadDataFile
{
// 最最常见的一种情况
// 打开IE,访问网站,提示你安装Flash插件
// 如果没有这个应用程序,是无法用UIWebView打开对应的文件的

// 应用场景:加载从服务器上下载的文件,例如pdf,或者word,图片等等文件
NSURL *fileURL = [[NSBundle mainBundle] URLForResource:@"iOS 7 Programming Cookbook.pdf" withExtension:nil];

NSURLRequest *request = [NSURLRequest requestWithURL:fileURL];
// 服务器的响应对象,服务器接收到请求返回给客户端的
NSURLResponse *respnose = nil;

NSData *data = [NSURLConnection sendSynchronousRequest:request returningResponse:&respnose error:NULL];

NSLog(@"%@", respnose.MIMEType);

// 在iOS开发中,如果不是特殊要求,所有的文本编码都是用UTF8
// 先用UTF8解释接收到的二进制数据流
[self.webView loadData:data MIMEType:respnose.MIMEType textEncodingName:@"UTF8" baseURL:nil];
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: