最近使用火车票网的限行网页,但是广告以及头部nav和地步footer都是我们现在所不需要的,所以决定使用js交互,下面所有代码都写在 webViewDidFinishLoad 里面
1.查看原网址的源代码:
NSString *js1 = @"document.documentElement.innerHTML"; NSString *pageSource = [webView stringByEvaluatingJavaScriptFromString:js1]; NSLog(@"pagesource:%@", pageSource);
2.编写js代码
NSMutableString *js = [NSMutableString string]; // 删除NAV [js appendString:@"var header = document.getElementById('huoche_nav');"];//获取id为huoche_nav节点 [js appendString:@"header.parentNode.removeChild(header);"];//把节点从父试图中删除 // 删除TOPBAR [js appendString:@"var box = document.getElementById('huoche_topbar');"]; [js appendString:@"box.parentNode.removeChild(box);"]; // 删除footer [js appendString:@"var buyNow = document.getElementById('footer');"]; [js appendString:@"buyNow.parentNode.removeChild(buyNow);"]; [js appendString:@"var form1 = document.getElementById('form1');"]; [js appendString:@"form1.parentNode.removeChild(form1);"]; [js appendString:@"var righttbox = document.getElementsByClassName('righttbox')[0];"]; [js appendString:@"righttbox.parentNode.removeChild(righttbox);"]; [js appendString:@"var height8 = document.getElementsByClassName('center_xianlu height8')[0];"]; [js appendString:@"height8.parentNode.removeChild(height8);"];
3.在webview的代理方法webViewDidFinishLoad中执行js代码
[webView stringByEvaluatingJavaScriptFromString:js];
4.如果需要使用uiwebview双指变大变小,需要添加
webview.scalesPageToFit=YES; webview.multipleTouchEnabled=YES; webview.userInteractionEnabled=YES;
总结:
1.
NSURL *url = [[NSBundle mainBundle] URLForResource:@"index" withExtension:@"html"]; NSURLRequest *request = [NSURLRequest requestWithURL:url]; [self.webView loadRequest:request];
2.
NSString *str1 = @"var word = document.getElementById('word');"; NSString *str2 = @"word.remove();"; [webView stringByEvaluatingJavaScriptFromString:str1]; [webView stringByEvaluatingJavaScriptFromString:str2];
3.
NSString *str3 = @"var change = document.getElementsByClassName('change')[0];" "change.innerHTML = '!';"; [webView stringByEvaluatingJavaScriptFromString:str3];
4.
NSString *str4 =@"var img = document.createElement('img');" "img.src = 'img_01.jpg';" "img.width = '160';" "img.height = '80';" "document.body.appendChild(img);"; [webView stringByEvaluatingJavaScriptFromString:str4];
5.
NSString *str1 = @"var h1 = document.getElementsByTagName('h1')[0];" "h1.innerHTML='';"; [webView stringByEvaluatingJavaScriptFromString:str1];
6.
NSString *str2 =@"document.getElementById('footer').remove();"; [webView stringByEvaluatingJavaScriptFromString:str2];
7.
NSString *str3 = @"document.body.outerHTML"; NSString *html = [webView stringByEvaluatingJavaScriptFromString:str3]; NSLog(@"%@", html);
在html中调用OC
-(BOOL)webView:(UIWebView *)webView shouldStartLoadWithRequest: (NSURLRequest *)request navigationType: (UIWebViewNavigationType)navigationType{ NSString *str = request.URL.absoluteString; NSRange range = [str rangeOfString:@"ZJY://"]; if (range.location != NSNotFound) { NSString *method = [str substringFromIndex:range.location + range.length]; SEL sel = NSSelectorFromString(method); [self performSelector:sel]; }return YES; }