- (void)webViewDidFinishLoad:(UIWebView *)webView {
[IDProgressHUD IDPlaceViewHideDirect:self.view]
//这里是js,主要目的实现对url的获取
static NSString * const jsGetImages =
@"function getImages(){\
var objs = document.getElementsByTagName(\"img\")\
var imgScr = ''\
for(var i=0i<objs.lengthi++){\
imgScr = imgScr + objs[i].src + '+'\
}\
return imgScr\
}"
[webView stringByEvaluatingJavaScriptFromString:jsGetImages]//注入js方法
NSString *urlResurlt = [webView stringByEvaluatingJavaScriptFromString:@"getImages()"]
mUrlArray = [NSMutableArray arrayWithArray:[urlResurlt componentsSeparatedByString:@"+"]]
if (mUrlArray.count >= 2) {
[mUrlArray removeLastObject]
}
//urlResurlt 就是获取到得所有图片的url的拼接;mUrlArray就是所有Url的数组
//添加图片可点击js
[mWebView stringByEvaluatingJavaScriptFromString:@"function registerImageClickAction(){\
var imgs=document.getElementsByTagName('img')\
var length=imgs.length\
for(var i=0i<lengthi++){\
img=imgs[i]\
img.onclick=function(){\
window.location.href='image-preview:'+this.src}\
}\
}"]
[mWebView stringByEvaluatingJavaScriptFromString:@"registerImageClickAction()"]
}
//在这个方法中捕获到图片的点击事件和被点击图片的url
- (BOOL)webView:(UIWebView *)webView shouldStartLoadWithRequest:(NSURLRequest *)request navigationType:(UIWebViewNavigationType)navigationType {
//预览图片
if ([request.URL.scheme isEqualToString:@"image-preview"]) {
NSString* path = [request.URL.absoluteString substringFromIndex:[@"image-preview:" length]]
path = [path stringByAddingPercentEscapesUsingEncoding:NSUTF8StringEncoding]
//path 就是被点击图片的url
return NO
}
return YES
}
<img src="http://img.baidu.com/img/iknow/avarta/66/r11s1g5.gif" onclick="window.open(this.src,'_blank')"/>onclick 点击图片事件
window.open('','') 打开一个新网页 第一个参数是网址 第二个是打开方式
window.open(this.src,'_blank') 以该图片的路径为网址,以新页的方式打开
使用以下关键代码:
1、简单的HTML页面,放入一些img标签:
2、页面载入完成后,读取img标签:
3、展示页面:
4、打开开发者模式,浏览器console:(已读取)
5、错误分析,getElementByTagName:(少了一个s,Elements)
扩展资料:
getElementsByTagName() 特性:
这方法会忽略文档的结构。假如希望查找文档中所有的 <p>元素,getElementsByTagName() 会把它们全部找到,不管 <p>元素处于文档中的哪个层次。
这方法会提供任何所需要的 HTML 元素,不论它们在文档中所处的位置。
1、getElementsByTagName() 方法会使用指定的标签名返回所有的元素(作为一个节点列表)
2、getElementsByTagName() 这方法可查找整个 HTML 文档中的任何 HTML 元素。