iOS OC和JS互調

最近朋友讓做一個webApp和原生的代碼互調恋技,就順便查了一下資料 總結分享一個

從iOS7開始 蘋果公布了JavaScriptCore.framework 它使得JS與OC的交互更加方便了。

下面我們就簡單了解一下這個框架

首先我導入framework

方法如下

點擊Linked Frameworks and Libraries 的添加后 選擇 JavaScriptCore.framework

選中JavaScriptCore.framework后 點擊右下角Add 添加完成

好 創(chuàng)建完成之后我們導入一下頭文件

[objc]view plaincopy

#import?

點進去 會看到如下幾個方法

#import"JSContext.h"

#import"JSValue.h"

#import"JSManagedValue.h"

#import"JSVirtualMachine.h"

#import"JSExport.h"

這些方法我們等會再細講

下來我們創(chuàng)建一個UIWebView ?用來測試

創(chuàng)建UIWebView

[objc]view plaincopy

UIWebView*myWebView;

初始化钙蒙,添加,打開網址

[objc]view plaincopy

//初始化webview

myWebView=[[UIWebViewalloc]initWithFrame:CGRectMake(0,22,?[UIScreenmainScreen].bounds.size.width,?[UIScreenmainScreen].bounds.size.height-22)];

myWebView.delegate=self;

//添加webview到當前viewcontroller的view上

[self.viewaddSubview:myWebView];

//網址

NSString*httpStr=@"https://www.baidu.com";

NSURL*httpUrl=[NSURLURLWithString:httpStr];

NSURLRequest*httpRequest=[NSURLRequestrequestWithURL:httpUrl];

[myWebViewloadRequest:httpRequest];

運行效果如下

下面我們來實現UIWebView的幾個代理方法

首先我們看下它的代理方法

[objc]view plaincopy

@protocolUIWebViewDelegate?

@optional

-?(BOOL)webView:(UIWebView*)webViewshouldStartLoadWithRequest:(NSURLRequest*)requestnavigationType:(UIWebViewNavigationType)navigationType;

-?(void)webViewDidStartLoad:(UIWebView*)webView;

-?(void)webViewDidFinishLoad:(UIWebView*)webView;

-?(void)webView:(UIWebView*)webViewdidFailLoadWithError:(NSError*)error;

@end

每個方法的作用等會在帶里面做注釋

首先我們添加協議

[objc]view plaincopy

@interfaceViewController?()

實現代理方法

[objc]view plaincopy

#pragma?mark?--webViewDelegate

-(BOOL)webView:(UIWebView*)webViewshouldStartLoadWithRequest:(NSURLRequest*)requestnavigationType:(UIWebViewNavigationType)navigationType

{

//網頁加載之前會調用此方法

//retrun?YES?表示正常加載網頁?返回NO?將停止網頁加載

returnYES;

}

-(void)webViewDidStartLoad:(UIWebView*)webView

{

//開始加載網頁調用此方法

}

-(void)webViewDidFinishLoad:(UIWebView*)webView

{

//網頁加載完成調用此方法

}

-(void)webView:(UIWebView*)webViewdidFailLoadWithError:(NSError*)error

{

//網頁加載失敗?調用此方法

}

每個方法是什么時候調用都在注釋里面

下來我們先嘗試用oc調用一下js方法

[objc]view plaincopy

-(void)webViewDidFinishLoad:(UIWebView*)webView

{

//網頁加載完成調用此方法

//首先創(chuàng)建JSContext?對象(此處通過當前webView的鍵獲取到jscontext)

JSContext*context=[webViewvalueForKeyPath:@"documentView.webView.mainFrame.javaScriptContext"];

NSString*alertJS=@"alert('test?js?OC')";//準備執(zhí)行的js代碼

[contextevaluateScript:alertJS];//通過oc方法調用js的alert

}

執(zhí)行效果如下:

好了遮斥,我們已經實現了iOS 調用js

原文地址:http://blog.csdn.net/lwjok2007/article/details/47058101

iOS和JS互調(二):http://blog.csdn.net/lwjok2007/article/details/47058795

IOS和JS通過橋接的方式進行互調:http://www.cocoachina.com/ios/20150814/12985.html

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
  • 序言:七十年代末休傍,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子穷当,更是在濱河造成了極大的恐慌,老刑警劉巖淹禾,帶你破解...
    沈念sama閱讀 222,729評論 6 517
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件馁菜,死亡現場離奇詭異,居然都是意外死亡稀拐,警方通過查閱死者的電腦和手機,發(fā)現死者居然都...
    沈念sama閱讀 95,226評論 3 399
  • 文/潘曉璐 我一進店門丹弱,熙熙樓的掌柜王于貴愁眉苦臉地迎上來德撬,“玉大人铲咨,你說我怎么就攤上這事◎押椋” “怎么了纤勒?”我有些...
    開封第一講書人閱讀 169,461評論 0 362
  • 文/不壞的土叔 我叫張陵,是天一觀的道長隆檀。 經常有香客問我摇天,道長,這世上最難降的妖魔是什么恐仑? 我笑而不...
    開封第一講書人閱讀 60,135評論 1 300
  • 正文 為了忘掉前任泉坐,我火速辦了婚禮,結果婚禮上裳仆,老公的妹妹穿的比我還像新娘腕让。我一直安慰自己,他們只是感情好歧斟,可當我...
    茶點故事閱讀 69,130評論 6 398
  • 文/花漫 我一把揭開白布纯丸。 她就那樣靜靜地躺著,像睡著了一般静袖。 火紅的嫁衣襯著肌膚如雪觉鼻。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 52,736評論 1 312
  • 那天队橙,我揣著相機與錄音坠陈,去河邊找鬼。 笑死喘帚,一個胖子當著我的面吹牛畅姊,可吹牛的內容都是我干的。 我是一名探鬼主播吹由,決...
    沈念sama閱讀 41,179評論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼若未,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了倾鲫?” 一聲冷哼從身側響起粗合,我...
    開封第一講書人閱讀 40,124評論 0 277
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎乌昔,沒想到半個月后隙疚,有當地人在樹林里發(fā)現了一具尸體,經...
    沈念sama閱讀 46,657評論 1 320
  • 正文 獨居荒郊野嶺守林人離奇死亡磕道,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 38,723評論 3 342
  • 正文 我和宋清朗相戀三年供屉,在試婚紗的時候發(fā)現自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 40,872評論 1 353
  • 序言:一個原本活蹦亂跳的男人離奇死亡伶丐,死狀恐怖悼做,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情哗魂,我是刑警寧澤肛走,帶...
    沈念sama閱讀 36,533評論 5 351
  • 正文 年R本政府宣布,位于F島的核電站录别,受9級特大地震影響朽色,放射性物質發(fā)生泄漏。R本人自食惡果不足惜组题,卻給世界環(huán)境...
    茶點故事閱讀 42,213評論 3 336
  • 文/蒙蒙 一葫男、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧往踢,春花似錦腾誉、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,700評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至瘦癌,卻和暖如春猪贪,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背讯私。 一陣腳步聲響...
    開封第一講書人閱讀 33,819評論 1 274
  • 我被黑心中介騙來泰國打工热押, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人斤寇。 一個月前我還...
    沈念sama閱讀 49,304評論 3 379
  • 正文 我出身青樓桶癣,卻偏偏與公主長得像,于是被迫代替她去往敵國和親娘锁。 傳聞我的和親對象是個殘疾皇子牙寞,可洞房花燭夜當晚...
    茶點故事閱讀 45,876評論 2 361

推薦閱讀更多精彩內容