- (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
}
在javascript中,可以为某个元素指定事件,指定的方式有以下三种:1、在html中,使用onclick属性
2、在javascript中,使用onclick属性
(1)注意函数名没有双引号。
3、在javascipt中,使用addEvenListener()方法
三种方法的比较
(1)在第二、三种方法中,可以向函数传入一个event对象,并读取其相应属性,而方法一不可以。
一些语法细节
(1)在第一种方法中,onclick大小写无关,但在第二种方法中,必须使用小写。因为HMTL对大小写不敏感,而JS则会区分大小写。
(2)在第二、三种方法中,指定函数名时没有双引号,而第一种作为一个HTML属性,需要双引号。
(3)第一种方法需要括号,第二、三种不需要。
onclick="clickHandler()"
document.getElementById("jsOnClick").onclick = clickHandler2
document.getElementById("adEventListener").addEventListener("click",clickHandler2)