UIWebView與js交互

UIWebView是iOS最經常使用的SDK之一,它有一個stringByEvaluatingJavaScriptFromString方法能夠將javascript嵌入頁面中,經過這個方法咱們能夠在iOS中與UIWebView中的網頁元素交互。
stringByEvaluatingJavaScriptFromString
    使用stringByEvaluatingJavaScriptFromString方法,須要等UIWebView中的頁面加載完成以後去調用。咱們 在界面上拖放一個UIWebView控件。在Load中將google mobile加載到這個控件中,代碼以下:
 
- (void)viewDidLoad
{
    [super viewDidLoad];
    webview.backgroundColor = [UIColor clearColor];
    webview.scalesPageToFit =YES;
    webview.delegate =self;
    NSURL *url =[[NSURL alloc] initWithString:@"http://www.google.com.hk/m?gl=CN&hl=zh_CN&source=ihp"];
 
    NSURLRequest *request =  [[NSURLRequest alloc] initWithURL:url];
    [webview loadRequest:request];
}
 
咱們在webViewDidFinishLoad方法中就能夠經過javascript操做界面元素了。
一、獲取當前頁面的url。
 
- (void)webViewDidFinishLoad:(UIWebView *)webView {
  NSString *currentURL = [webView stringByEvaluatingJavaScriptFromString:@"document.location.href"];
}
 
二、獲取頁面title:
 
- (void)webViewDidFinishLoad:(UIWebView *)webView {
   NSString *currentURL = [webView stringByEvaluatingJavaScriptFromString:@"document.location.href"];
 
   NSString *title = [webview stringByEvaluatingJavaScriptFromString:@"document.title"];
}
 
三、修改界面元素的值。
 
 NSString *js_result = [webView stringByEvaluatingJavaScriptFromString:@"document.getElementsByName('q')[0].value='朱祁林';"];
 
四、表單提交:
 
NSString *js_result2 = [webView stringByEvaluatingJavaScriptFromString:@"document.forms[0].submit(); "]
 
這樣就實現了在google搜索關鍵字:「朱祁林」的功能。
五、插入js代碼
上面的功能咱們能夠封裝到一個js函數中,將這個函數插入到頁面上執行,代碼以下:
 
 [webView stringByEvaluatingJavaScriptFromString:@"var script = document.createElement('script');"
         "script.type = 'text/javascript';"
         "script.text = \"function myFunction() { "
         "var field = document.getElementsByName('q')[0];"
         "field.value='朱祁林';"
         "document.forms[0].submit();"
         "}\";"
         "document.getElementsByTagName('head')[0].appendChild(script);"];   
 
        [webView stringByEvaluatingJavaScriptFromString:@"myFunction();"];
 
看上面的代碼:
a、首先經過js建立一個script的標籤,type爲'text/javascript'。
b、而後在這個標籤中插入一段字符串,這段字符串就是一個函數:myFunction,這個函數實現google自動搜索關鍵字的功能。
c、而後使用stringByEvaluatingJavaScriptFromString執行myFunction函數。
相關文章
相關標籤/搜索