UIWebView的使用与总结

hh.jpeg

先前在项目中使用了UIWebView 在项目中一些比较复杂的UI布局、需后台灵活控制的界面、原网页,可以考虑UIWebView 在用它之前跟大家说下它的优缺点 优点:

  • 可跨平台 开发一次可以部署iOS、Android等平台。
  • 发布更新快 在服务器端发布,能够实时更新终端展示,便于快速升级以及紧急修复bug
  • 排版布局能力强 强大的HTML+CSS让人膜拜 缺点:
  • 性能 相对于原生的app来说,使用UIWebViewapp相对来说性能会低一点, 用户的体验度也会大打折扣
  • 数据通讯复杂UIWebViewApp之间进行数据通讯只能通过javascriptUIWebViewDelegate来进行,客户端想传参数给UIWebView修改网页或 者从网页中获取数据都比较复杂。具体的操作如下

更多经验请点击

UIWebView的常规使用方法: //加载网页或者本地文件 - (void)loadRequest:(NSURLRequest *)request;//直接加载html内容,如果html中的图片等资源在本地目录,注意将baseURL指向该目录 - (void)loadHTMLString:(NSString *)string baseURL:(NSURL *)baseURL;//功能与上面类似 - (void)loadData:(NSData *)data MIMEType:(NSString *)MIMEType textEncodingName:(NSString *)textEncodingName baseURL:(NSURL *)baseURL; 实现UIWebViewDelegate主要使用到的方法 -(BOOL)webView:(UIWebView*)webView shouldStartLoadWithRequest:(NSURLRequest*) reuqest navigationType:(UIWebViewNavigationType)navigationType;//当网页视图被指示载入内容而得到通知。应当返回YES,这样会进行加载。通过导航类型参数可以得到请求发起的原因,可以是以下任意值: UIWebViewNavigationTypeLinkClicked //判断是否是点击事件 UIWebViewNavigationTypeFormSubmitted UIWebViewNavigationTypeBackForward UIWebViewNavigationTypeReload UIWebViewNavigationTypeFormResubmitted UIWebViewNavigationTypeOther 通过 NSURL *url = [request URL]; NSString *curUrl= [url absoluteString]; 可得到点击事件的URL -(void)webViewDidStartLoad:(UIWebView*)webView ;//当网页视图已经开始加载一个请求后,得到通知。 -(void)webViewDidFinishLoad:(UIWebView*)webView ;//当网页视图结束加载一个请求之后,得到通知。 -(void)webView:(UIWebView*)webView DidFailLoadWithError:(NSError*)error;//当在请求加载中发生错误时,得到通知。会提供一个NSSError对象,以标识所发生错误类型。 设置背景透明:webView.backgroundColor= [UIColor clearColor];webView.opaque=NO; 自动适配屏幕: webView.scalespageToFit = YES; 自动检测网页上的电话号码,点击可拨号 webView.detectsPhoneNumbers = YES; 与js交互

我们在webViewDidFinishLoad方法中就可以通过javascript操作界面元素了。
1、获取当前页面的url。
- (void)webViewDidFinishLoad:(UIWebView *)webView {NSString *currentURL = [webView stringByEvaluatingJavaScriptFromString:@"document.location.href"];}
2、获取页面title:
- (void)webViewDidFinishLoad:(UIWebView *)webView {NSString *currentURL = [webView stringByEvaluatingJavaScriptFromString:@"document.location.href"];NSString *title = [webview stringByEvaluatingJavaScriptFromString:@"document.title"];}

推荐一款学习iOS开发的app_____|______| | 传送门 技术交流群:534926022(免费) 511040024(0.8/人付费) 原文在:http://www.allluckly.cn/ 版权归©Bison所有 如需转载请保留原文超链接地址!否则后果自负!

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏移动端周边技术扩展

WKWebView实现简单的轻应用

2007
来自专栏雨尘分享

iOS 和 H5 交互那些事 (UIWebView、WKWebView 总结篇)

9815
来自专栏有困难要上,没有困难创造困难也要上!

Electron 创建桌面应用

34616
来自专栏向治洪

IOS WebView控件详解

概述 WebView就是一个内嵌浏览器控件,在iOS中主要有两种WebView:UIWebView和WKWebView,UIWebView是iOS2之后开始使用...

4976
来自专栏乐沙弥的世界

Linux 下配置 HugePages

    HugePages是通过使用大页内存来取代传统的4kb内存页面,使得管理虚拟地址数变少,加快了从虚拟地址到物理地址的映射以及通过摒弃内存页面的换入换出以...

904
来自专栏腾讯Bugly的专栏

WKWebView 那些坑

导语 WKWebView 是苹果在 WWDC 2014 上推出的新一代 webView 组件,用以替代 UIKit 中笨重难用、内存泄漏的 UIWebView。...

79412
来自专栏朱慕之的博客

WKWebView

我们要通过JS与webview内容交互,就需要到这个类了,它的所有属性及方法说明如下:

1091
来自专栏哈雷彗星撞地球

iOS下JS与OC互相调用(六)--WKWebView + WebViewJavascriptBridge

上一篇文章介绍了UIWebView 如何通过WebViewJavascriptBridge 来实现JS 与OC 的互相调用,这一篇来介绍一下WKWebView ...

792
来自专栏编程语言

iOS 无弹框换图标,直接用就可以了

        对于iOS,是开发了API可以换图标,但是有规定的,就是你要换的图标是要在APP里面内置的,也就是说你要换的APPicon,是提前放在APP包里...

802
来自专栏移动端开发

WKWebView的使用与JS交互详细解读

前言:     WKWebView 这是在iOS8.0之后增加的一个比UIWebView更加完善和强大的控件!看网上关于它的博客也是有许多的了,从各个方面总结一...

3597

扫码关注云+社区