UIWebView和网页的交互(OC中调执行JS)
来源:互联网 发布:幻灯片软件 编辑:程序博客网 时间:2024/05/01 19:56
UIWebView和网页的交互(OC中调执行JS)
- (void)viewDidLoad
{
[superviewDidLoad];
// 1.webView
UIWebView *webView = [[UIWebViewalloc]init];
webView.frame= self.view.bounds;
webView.delegate= self;
// 伸缩页面至填充整个webView
webView.scalesPageToFit= YES;
// 隐藏scrollView
webView.scrollView.hidden= YES;
[self.viewaddSubview:webView];
// 2.加载网页
NSURLRequest *request = [NSURLRequestrequestWithURL:[NSURLURLWithString:@"http://m.dianping.com/tuan/deal/5501525"]];
[webView loadRequest:request];
// 3.创建
UIActivityIndicatorView *loadingView = [[UIActivityIndicatorViewalloc]initWithActivityIndicatorStyle:UIActivityIndicatorViewStyleWhiteLarge];
[loadingView startAnimating];
loadingView.center= CGPointMake(160,240);
[self.viewaddSubview:loadingView];
self.loadingView= loadingView;
}
//在OC中调用JS
#pragma mark - UIWebViewDelegate
- (void)webViewDidFinishLoad:(UIWebView*)webView
{
NSMutableString *js1 = [NSMutableStringstring];
// 0.删除顶部的导航条
[js1 appendString:@"var header = document.getElementsByTagName('header')[0];"];
[js1 appendString:@"header.parentNode.removeChild(header);"];
// 1.删除底部的链接
[js1 appendString:@"var footer = document.getElementsByTagName('footer')[0];"];
[js1 appendString:@"footer.parentNode.removeChild(footer);"];
[webView stringByEvaluatingJavaScriptFromString:js1];
dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(0.25* NSEC_PER_SEC)),dispatch_get_main_queue(), ^{
NSMutableString *js2 = [NSMutableStringstring];
// 2.删除浮动的广告
[js2 appendString:@"var list = document.body.childNodes;"];
[js2 appendString:@"var len = list.length;"];
[js2 appendString:@"var banner = list[len - 1];"];
[js2 appendString:@"banner.parentNode.removeChild(banner);"];
[webView stringByEvaluatingJavaScriptFromString:js2];
// 显示scrollView
webView.scrollView.hidden= NO;
// 删除圈圈
[self.loadingViewremoveFromSuperview];
});
}
{
[superviewDidLoad];
// 1.webView
UIWebView *webView = [[UIWebViewalloc]init];
webView.frame= self.view.bounds;
webView.delegate= self;
// 伸缩页面至填充整个webView
webView.scalesPageToFit= YES;
// 隐藏scrollView
webView.scrollView.hidden= YES;
[self.viewaddSubview:webView];
// 2.加载网页
NSURLRequest *request = [NSURLRequestrequestWithURL:[NSURLURLWithString:@"http://m.dianping.com/tuan/deal/5501525"]];
[webView loadRequest:request];
// 3.创建
UIActivityIndicatorView *loadingView = [[UIActivityIndicatorViewalloc]initWithActivityIndicatorStyle:UIActivityIndicatorViewStyleWhiteLarge];
[loadingView startAnimating];
loadingView.center= CGPointMake(160,240);
[self.viewaddSubview:loadingView];
self.loadingView= loadingView;
}
//在OC中调用JS
#pragma mark - UIWebViewDelegate
- (void)webViewDidFinishLoad:(UIWebView*)webView
{
NSMutableString *js1 = [NSMutableStringstring];
// 0.删除顶部的导航条
[js1 appendString:@"var header = document.getElementsByTagName('header')[0];"];
[js1 appendString:@"header.parentNode.removeChild(header);"];
// 1.删除底部的链接
[js1 appendString:@"var footer = document.getElementsByTagName('footer')[0];"];
[js1 appendString:@"footer.parentNode.removeChild(footer);"];
[webView stringByEvaluatingJavaScriptFromString:js1];
dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(0.25* NSEC_PER_SEC)),dispatch_get_main_queue(), ^{
NSMutableString *js2 = [NSMutableStringstring];
// 2.删除浮动的广告
[js2 appendString:@"var list = document.body.childNodes;"];
[js2 appendString:@"var len = list.length;"];
[js2 appendString:@"var banner = list[len - 1];"];
[js2 appendString:@"banner.parentNode.removeChild(banner);"];
[webView stringByEvaluatingJavaScriptFromString:js2];
// 显示scrollView
webView.scrollView.hidden= NO;
// 删除圈圈
[self.loadingViewremoveFromSuperview];
});
}
注意:
从网络上获取数据,如果不想看到某种效果,并且网页存放在服务器端,里面的JS和Html代码,没有办法修改,可以在UIWebView的代理方法执行JS代码,去掉不想看到的效果。
0 0
- UIWebView和网页的交互(OC中调执行JS)
- UIWebView和网页的交互(JS中调用OC代码)
- iOS - OC和网页JS的交互
- OC里面UIWebView中js交互
- UIWebview中 js 的执行结果返回给OC ,js 回传OC
- oc 和 h5中js 的交互
- UIWebView和网页交互的研究初探
- UIWebView和网页交互的研究初探
- iOS网页-JS交互(UIWebView)
- 史上最全的 UIWebview 的 JS 与 OC 交互
- 史上最全的 UIWebview 的 JS 与 OC 交互
- iOS 开发 Object-C和JavaScript交互详解之OC与JS交互在UIWebView中使用
- UIWebView和js交互
- UIWebView和Js交互
- OC 和JS的交互
- OC与JS交互之UIWebView
- OC 与 JS 交互 (UIWebView & WKWebView)
- OC与JS交互之UIWebView
- wp开发 progress bar的制作
- [操作系统]iOS开发之使用CocoaPods更新第三方出现“target overrides the `OTHER_LDFLAGS`……”问题解决方案
- 酷宝童车便携式代步系列近二百款
- BP 神经网络的 MATLAB 实现步骤
- 第十五周上机项目2--(2) 阅读程序
- UIWebView和网页的交互(OC中调执行JS)
- 基础知识汇总
- AUCTeX+Emacs 是目前我见过的能最大限度提高 LaTeX 编辑效率的编辑器 (转)
- OC学习篇之---类的三大特性(封装,继承,多态)
- 今天做了一个重要的决定,总之不后悔,按照自己的目标努力就好!
- 3范式
- 第十五周项目3——在OJ上玩指针(3)
- 《UNIX环境高级编程》单个源码编译方法(转)
- jdk安装配置