iOS webView获取html内容


标签:
杂谈 |
分类: 控件处理 |
}
我们在webViewDidFinishLoad方法中就可以通过javascript操作界面元素了。
1、获取当前页面的url。
-
-
(void)webViewDidFinishLoad:(UIWebView *)webView { -
NSString *currentURL = [webView stringByEvaluatingJavaSc riptFromString:@"document.location.href"];
2、获取页面title:
-
NSString
*title = [webview stringByEvaluatingJavaSc riptFromString:@"document.title"];
3、修改界面元素的值。
-
NSString
*js_result = [webView stringByEvaluatingJavaSc riptFromString:@"document.getElementsByName('q')[0].value='朱祁林';"];
4、表单提交:
-
NSString
*js_result2 = [webView stringByEvaluatingJavaSc riptFromString:@"document.forms[0].submit(); "];
这样就实现了在google搜索关键字:“朱祁林”的功能。
5、插入js代码
上面的功能我们可以封装到一个js函数中,将这个函数插入到页面上执行,代码如下:
-
if
([title compare: @"Google"]==NSOrderedSame ) { -
-
[webView stringByEvaluatingJavaSc riptFromString:@"var script = document.createElement_x('script');" -
"script.type = 'text/javascript';" -
"script.text = "function myFunction() { " -
"var field = document.getElementsByName('q')[0];" -
"field.value='朱祁林';" -
"document.forms[0].submit();" -
"}";" -
"document.getElementsByTagName_r('head')[0].appendChild(script);"]; -
-
[webView stringByEvaluatingJavaSc riptFromString:@"myFunction();"]; -
}
看上面的代码:
a、首先通过js创建一个script的标签,type为'text/javascript'。
b、然后在这个标签中插入一段字符串,这段字符串就是一个函数:myFunction,这个函数实现google自动搜索关键字的功能。
c、然后使用stringByEvaluatingJavaSc
演示:
第一步打开google mobile网站
http://hi.csdn.net/attachment/201108/4/0_13124170981Cg7.gifwebView获取html内容" />
第二步输入关键字
http://hi.csdn.net/attachment/201108/4/0_13124171126OOZ.gifwebView获取html内容" />
第三步搜素
http://hi.csdn.net/attachment/201108/4/0_1312417131AsZE.gifwebView获取html内容" />
总结:这篇文章主要是讲解了stringByEvaluatingJavaSc