native與h5交互

http://www.cocoachina.com/ios/20160127/15105.html

WKWebView

WKWebView用于ios8+

JavaScriptCore

iOS7之后蘋果推出了JavaScriptCore這個框架涩盾,從而讓web頁面和本地原生應(yīng)用交互起來非常方便叶眉,而且使用此框架可以做到Android那邊和iOS相對統(tǒng)一莲趣,web前端寫一套代碼就可以適配客戶端的兩個平臺走芋,從而減少了web前端的工作量。
web前端去定義方法名,iOS和Android根據(jù)web前端定義好的去寫代碼怨喘。JavaScriptCore中web頁面調(diào)用原生應(yīng)用的方法可以用Delegate或Block兩種方法吩案,此文以按Delegate講解靠益。
ViewController中的代碼

#import "ViewController.h"
#import [JavaScriptCore/JavaScriptCore.h](此處為尖括號)
 
@protocol JSObjcDelegate [JSExport](此處為尖括號)
 
- (void)callCamera;
- (void)share:(NSString *)shareString;
 
@end
 
@interface ViewController () [UIWebViewDelegate, JSObjcDelegate](此處為尖括號)
 
@property (nonatomic, strong) JSContext *jsContext;
@property (weak, nonatomic) IBOutlet UIWebView *webView;
 
@end
 
@implementation ViewController
 
#pragma mark - Life Circle
 
- (void)viewDidLoad {
    [super viewDidLoad];
     
    NSURL *url = [[NSBundle mainBundle] URLForResource:@"test" withExtension:@"html"];
    [self.webView loadRequest:[[NSURLRequest alloc] initWithURL:url]];
}
 
#pragma mark - UIWebViewDelegate
 
- (void)webViewDidFinishLoad:(UIWebView *)webView {
    self.jsContext = [webView valueForKeyPath:@"documentView.webView.mainFrame.javaScriptContext"];
    self.jsContext[@"Toyun"] = self;
    self.jsContext.exceptionHandler = ^(JSContext *context, JSValue *exceptionValue) {
        context.exception = exceptionValue;
        NSLog(@"異常信息:%@", exceptionValue);
    };
}
 
#pragma mark - JSObjcDelegate
 
- (void)callCamera {
    NSLog(@"callCamera");
    // 獲取到照片之后在回調(diào)js的方法picCallback把圖片傳出去
    JSValue *picCallback = self.jsContext[@"picCallback"];
    [picCallback callWithArguments:@[@"photos"]];
}
 
- (void)share:(NSString *)shareString {
    NSLog(@"share:%@", shareString);
    // 分享成功回調(diào)js的方法shareCallback
    JSValue *shareCallback = self.jsContext[@"shareCallback"];
    [shareCallback callWithArguments:nil];
}
 
@end
ViewController中的代碼解釋

自定義JSObjcDelegate協(xié)議胧后,而且此協(xié)議必須遵守JSExport這個協(xié)議,自定義協(xié)議中的方法就是暴露給web頁面的方法抱环。在webView加載完畢的時候獲取JavaScript運行的上下文環(huán)境镇草,然后再注入橋梁對象名為Toyun,承載的對象為self即為此控制器,控制器遵守此自定義協(xié)議實現(xiàn)協(xié)議中對應(yīng)的方法祟偷。在JavaStript調(diào)用完本地應(yīng)用的方法做完相對應(yīng)的事情之后,又回調(diào)了JavaStript中對應(yīng)的方法,從而實現(xiàn)了web頁面和本地應(yīng)用之間的通訊。

JavaScriptCore使用注意

JavaStript調(diào)用本地方法是在子線程中執(zhí)行的撩笆,這里要根據(jù)實際情況考慮線程之間的切換捺球,而在回調(diào)JavaScript方法的時候最好是在剛開始調(diào)用此方法的線程中去執(zhí)行那段JavaStript方法的代碼,我在實際運用中開始沒注意歹鱼,就被坑慘了啊泣栈。什么,說的太繞弥姻,看下面的代碼解釋:

//  假設(shè)此方法是在子線程中執(zhí)行的南片,線程名sub-thread
- (void)callCamera {     
    // 這句假設(shè)要在主線程中執(zhí)行,線程名main-thread
    NSLog(@"callCamera");
       
    // 下面這兩句代碼最好還是要在子線程sub-thread中執(zhí)行啊
    JSValue *picCallback = self.jsContext[@"picCallback"];
    [picCallback callWithArguments:@[@"photos"]];
}
攔截協(xié)議

攔截協(xié)議這個適合一些比較簡單的一些情況庭敦,不需要引入什么框架疼进,只需要web前端配合一下就好。但是在具體調(diào)用哪一個方法上秧廉,以及在傳值的時候可能會有些不方便伞广,而且調(diào)用完后無法在回調(diào)JavaScript的方法

- (BOOL)webView:(UIWebView *)webView shouldStartLoadWithRequest:(NSURLRequest *)request navigationType:(UIWebViewNavigationType)navigationType
{
    NSString *url = request.URL.absoluteString;
    if ([url rangeOfString:@"toyun://"].location != NSNotFound) {
        // url的協(xié)議頭是Toyun
        NSLog(@"callCamera");
        return NO;
    }
    return YES;
}
iOS對應(yīng)的代碼的解釋

在webView的代理方法中去攔截自定義的協(xié)議Toyun://如果是此協(xié)議則據(jù)此判斷JavaStript想要做的事情,調(diào)用原生應(yīng)用的方法疼电,這些都是提前約定好的嚼锄,同時阻止此鏈接的跳轉(zhuǎn)。

理解

h5會在點擊某按鈕是發(fā)起url請求蔽豺,而我們可以在代理方法中對該方法進(jìn)行攔截区丑。當(dāng)此功能是開放給native的,web會自定義特定的url開頭茫虽,所以native就可以通過過濾是否是特定的url來攔截此請求刊苍,同時根據(jù)url中的不同信息作出不同響應(yīng)既们。但是native響應(yīng)后無法回調(diào)給h5。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末正什,一起剝皮案震驚了整個濱河市啥纸,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌婴氮,老刑警劉巖斯棒,帶你破解...
    沈念sama閱讀 216,744評論 6 502
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異主经,居然都是意外死亡荣暮,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,505評論 3 392
  • 文/潘曉璐 我一進(jìn)店門罩驻,熙熙樓的掌柜王于貴愁眉苦臉地迎上來穗酥,“玉大人,你說我怎么就攤上這事惠遏±荆” “怎么了?”我有些...
    開封第一講書人閱讀 163,105評論 0 353
  • 文/不壞的土叔 我叫張陵节吮,是天一觀的道長抽高。 經(jīng)常有香客問我,道長透绩,這世上最難降的妖魔是什么翘骂? 我笑而不...
    開封第一講書人閱讀 58,242評論 1 292
  • 正文 為了忘掉前任,我火速辦了婚禮帚豪,結(jié)果婚禮上碳竟,老公的妹妹穿的比我還像新娘。我一直安慰自己志鞍,他們只是感情好瞭亮,可當(dāng)我...
    茶點故事閱讀 67,269評論 6 389
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著固棚,像睡著了一般统翩。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上此洲,一...
    開封第一講書人閱讀 51,215評論 1 299
  • 那天厂汗,我揣著相機(jī)與錄音,去河邊找鬼呜师。 笑死娶桦,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播衷畦,決...
    沈念sama閱讀 40,096評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼栗涂,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了祈争?” 一聲冷哼從身側(cè)響起斤程,我...
    開封第一講書人閱讀 38,939評論 0 274
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎菩混,沒想到半個月后忿墅,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,354評論 1 311
  • 正文 獨居荒郊野嶺守林人離奇死亡沮峡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,573評論 2 333
  • 正文 我和宋清朗相戀三年疚脐,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片邢疙。...
    茶點故事閱讀 39,745評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡棍弄,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出疟游,到底是詐尸還是另有隱情照卦,我是刑警寧澤,帶...
    沈念sama閱讀 35,448評論 5 344
  • 正文 年R本政府宣布乡摹,位于F島的核電站,受9級特大地震影響采转,放射性物質(zhì)發(fā)生泄漏聪廉。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,048評論 3 327
  • 文/蒙蒙 一故慈、第九天 我趴在偏房一處隱蔽的房頂上張望板熊。 院中可真熱鬧,春花似錦察绷、人聲如沸干签。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,683評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至闸度,卻和暖如春竭贩,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背莺禁。 一陣腳步聲響...
    開封第一講書人閱讀 32,838評論 1 269
  • 我被黑心中介騙來泰國打工留量, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 47,776評論 2 369
  • 正文 我出身青樓楼熄,卻偏偏與公主長得像忆绰,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子可岂,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,652評論 2 354

推薦閱讀更多精彩內(nèi)容