- (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
}
可以使用动作绑定,增加一个监听事件就可以了!但是监听对于IE的支持比较好,还可以使用其他方式如:img.onmouseover这种试进行.
我随便写一个你试一下:
event.onmouseover=function(){
if(this.srcElement.tagName=="IMG"){
执行相应语句块
}
}
这个是每点onmouseover时都检查一下其源是否为IMG,若是则执行一个事件!这是最简单的支持IE的写法!
html页面设置onClick事件可以在html中设置,也可以在js中设置,下面分别介绍。
在html中设置你的代码就是在html中设置的方法,这是测试页面,
现在html代码的元素中添加onclick
<input type="text" id="text" onClick="f()">
再在js代码中声明一个函数
function f(){
alert(1)
}
只在js中设置第二种方法是只在js中设置,这是测试页面
html代码可以更加纯粹,不用写onclick
<input type="text" id="text">
在js代码中,先找到这个元素,再去绑定一个事件
window.onload = function() {
document.getElementById("text").onclick = function() {
alert(1)
}
}
也可以实现这个效果
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)