iOS原生APP與H5+JS交互////////////////////zzzz

 原生代碼中直接加載頁面

1.    具體案例

加載本地/網絡HTML5做爲功能介紹頁javascript

2.    代碼示例

//本地html

 

[objc]  view plain  copy
 
 在CODE上查看代碼片派生到個人代碼片
  1. -(void)loadLocalPage:(UIWebView*)webView  
  2. {  
  3.    NSString* htmlPath = [[NSBundle mainBundle]pathForResource:@"demo" ofType:@"html"];  
  4. NSString* appHtml =[NSString stringWithContentsOfFile:htmlPath encoding:NSUTF8StringEncodingerror:nil];  
  5. NSURL *baseURL = [NSURLfileURLWithPath:htmlPath];  
  6.  [webView loadHTMLString:appHtmlbaseURL:baseURL];  
  7. }  

//網絡java

 

[objc]  view plain  copy
 
 在CODE上查看代碼片派生到個人代碼片
  1. -(void)loadWebPage:(UIWebView *)webView  
  2. {  
  3.     NSURL *url = [NSURLURLWithString:@"http://www.baidu.com"];  
  4.     NSURLRequest *request = [NSURLRequestrequestWithURL:url];  
  5.     [webView loadRequest:request];  
  6. }  

 

3.    額外操做

a  iOS中承載網頁的容器是UIWebView,能夠藉助它的代理來監聽網頁加載狀況;ios

b  在加載過程當中,咱們還能夠獲取該網頁中的meta值,例如代碼:web

 

[objc]  view plain  copy
 
 在CODE上查看代碼片派生到個人代碼片
  1. NSString *shareUrl = [messWebViewstringByEvaluatingJavaScriptFromString:@"document.getElementsByName(\"shareUrl\")[0].content"];  

就是從meta中獲得shareUrl對應的value值;面試

c  截獲當前是發起的那種請求,以便native來作對應的控制,例如代碼:xcode

 

[objc]  view plain  copy
 
 在CODE上查看代碼片派生到個人代碼片
  1. - (BOOL)webView:(UIWebView*)webView shouldStartLoadWithRequest:(NSURLRequest *)requestnavigationType:(UIWebViewNavigationType)navigationType  
  2. {  
  3.     NSString *requestString = [[[request URL]absoluteString]stringByReplacingPercentEscapesUsingEncoding:NSUTF8StringEncoding];  
  4.     if ([requestString hasPrefix:@"http://customersharetrigger"]){  
  5.        //執行一些操做  
  6.         return NO;  
  7.     }  
  8.     return YES;  
  9. //能夠監聽到這個請求,從而達到控制做用;  

 

2、  原生代碼操做頁面元素

1.    具體案例

在嵌入H5後須要操做頁面元素網絡

2.    代碼示例

a、獲取當前頁面的url。app

 

[objc]  view plain  copy
 
 在CODE上查看代碼片派生到個人代碼片
  1. -(void)webViewDidFinishLoad:(UIWebView *)webView {   
  2.   NSString *currentURL = [webView stringByEvaluatingJavaScriptFromString:@"document.location.href"];  
  3. }  

 

b、獲取頁面title:lua

[objc]  view plain  copy
 
 在CODE上查看代碼片派生到個人代碼片
  1. NSString *currentURL = [webViewstringByEvaluatingJavaScriptFromString:@"document.location.href"];  
  2.   
  3.  NSString *title = [webviewstringByEvaluatingJavaScriptFromString:@"document.title"];  

 

c、修改界面元素的值。

 

[objc]  view plain  copy
 
 在CODE上查看代碼片派生到個人代碼片
  1. NSString *js_result = [webViewstringByEvaluatingJavaScriptFromString:@"document.getElementsByName('q')[0].value='朱祁林';"];  

d、表單提交:

 

[objc]  view plain  copy
 
 在CODE上查看代碼片派生到個人代碼片
  1. NSString *js_result2 =[webView stringByEvaluatingJavaScriptFromString:@"document.forms[0].submit();"];  

3.    代碼說明

stringByEvaluatingJavaScriptFromString方法能夠將javascript代碼片斷嵌入到頁面中,經過這個方法就可讓iOS與UIWebView中的網頁元素交互,例如上面的代碼片斷,它

功能很是的強大,用起來也相對簡單,經過它咱們能夠很方便的操做頁面元素,並且能直接插入一段JS方法,而後調用該方法執行;

  

3、  原生代碼處理本地H5+JS

1.    具體案例

須要動態顯示曲線圖,若是直接加載繪製圖形特別慢,因此採用本地放置模板,傳入參數,而後模板自動繪製,提升體驗,加快繪製;

2.    示例代碼

 

[objc]  view plain  copy
 
 在CODE上查看代碼片派生到個人代碼片
  1. -(void)loadWebPage:(UIWebView *)webView  
  2. {  
  3.     NSURL *localPathURL = [[NSBundlemainBundle] URLForResource:@"detail" withExtension:@"html"subdirectory:@"htmlResources"];  
  4.     NSString *localPathUrl = [localPathURLabsoluteString];  
  5.     NSString *localParamPathUrl = [NSStringstringWithFormat:@"%@?symbol=%@&t=%f",localPathUrl,self.stockCode,self.time];  
  6.     NSURL *requestURL = [NSURLURLWithString:localParamPathUrl];  
  7.     [webView loadRequest:[NSURLRequestrequestWithURL:requestURL]];  
  8.    
  9. }  

 

3.    代碼說明

a 這裏須要採用絕對路徑拖入H5模板,就是選擇CreateFolder Reference, 只有這樣才能保證H5能調用到本地的JS代碼,否則加載不成功,這個最初找了不少緣由,最後才發現是拖入時候選擇問題;

b 若是要加入參數,注意須要先轉成string,而後再轉爲URL;

  

4、  原生代碼與網頁交互通訊

1.    具體案例

原生代碼與H5相互調用方法,並傳遞參數,並且能回調數據;

2.    藉助第三方實現

WebViewJavascriptBridge,該開源庫很是完美的解決了原生代碼與H5交互,即互毆;

3.    代碼示例

1.初始化一個webview(viewdidload)

 

[objc]  view plain  copy
 
 在CODE上查看代碼片派生到個人代碼片
  1. UIWebView* webView =[[UIWebView alloc] initWithFrame:self.view.bounds];  
  2.     [self.view addSubview:webView];  

 

 2.將此webview與WebViewJavascriptBridge關聯(viewdidload)

 

 

[objc]  view plain  copy
 
 在CODE上查看代碼片派生到個人代碼片
  1. if (_bridge) { return; }  
  2.    
  3.   [WebViewJavascriptBridge enableLogging];  
  4.    
  5.   _bridge = [WebViewJavascriptBridgebridgeForWebView:webView webViewDelegate:self handler:^(id data,WVJBResponseCallback responseCallback) {  
  6.     NSLog(@"ObjC received message from JS:%@", data);  
  7.      
  8.     responseCallback(@"Response formessage from ObjC");  
  9.   }];  

此時webview就與js搭上橋了。下面就是方法的互調和參數的互傳。

 

 (1) js調oc方法(能夠經過data給oc方法傳值,使用responseCallback將值再返回給js)

 

 

[objc]  view plain  copy
 
 在CODE上查看代碼片派生到個人代碼片
  1. [_bridgeregisterHandler:@"testObjcCallback" handler:^(id data,WVJBResponseCallback responseCallback) {  
  2.         NSLog(@"testObjcCallback called:%@", data);  
  3.         responseCallback(@"Response fromtestObjcCallback");  
  4.     }];  

 

  這裏注意testObjcCallback這個方法的標示。html那邊的命名要跟ios這邊相同,才能調到這個方法。固然這個名字能夠兩邊商量着自定義。簡單明確便可。

 

  (2)oc調js方法(經過data能夠傳值,經過 response能夠接受js那邊的返回值 )

 

[objc]  view plain  copy
 
 在CODE上查看代碼片派生到個人代碼片
  1.    
  2. id data = @{@"greetingFromObjC": @"Hi there, JS!" };  
  3.     [_bridgecallHandler:@"testJavascriptHandler" data:data responseCallback:^(idresponse) {  
  4.         NSLog(@"testJavascriptHandlerresponded: %@", response);  
  5.     }];  

 

 注意這裏的 testJavascriptHandler也是個方法標示。

 

 (3)oc給js傳值(經過 response接受返回值 )

 

 

[objc]  view plain  copy
 
 在CODE上查看代碼片派生到個人代碼片
  1. [_bridge send:@"Astring sent from ObjC to JS" responseCallback:^(id response) {  
  2.         NSLog(@"sendMessage got response:%@", response);  
  3.     }];  

 

  (4)oc給js傳值(無返回值)

 

[objc]  view plain  copy
 
 在CODE上查看代碼片派生到個人代碼片
  1. [_bridge send:@"A string sent from ObjC after Webview hasloaded."];  
  2.    
  3.    

 

5、 總結

關於Native和H5的交互有各類形式,隨着H5愈來愈成熟,將來的趨勢就是二者如影隨行,讓App更具靈活性和實效性,也必定程度上提升了開發效率和迭代週期,是企業級移動應用開發的必選解決方案,推薦:IT面試寶典(典型)

相關文章
相關標籤/搜索