先來看看如何在項目中的webview上面點擊一個按鈕,就能達到調用oc代碼
上面的這個頁面是webview裡面嵌套的一個項目的網頁,打印訂單點擊之後(點擊事件是一個js方法),需要調用oc裡面集成好的藍牙打印機功能,來完成打印。
所以這裡只能用js代碼來直接調用oc代碼。
1.首先創建一個iOS類,因為這裡一般都需要安卓端做一套,iOS端做一套,所以一般這樣命名以示區別
.h #import <Foundation/Foundation.h> #import <JavaScriptCore/JavaScriptCore.h> /** * js調用oc裡 main的代碼,需要借助這個協議才行 */ @protocol JSObjectProtocol <JSExport> @required #pragma mark -js調用該oc方法,並且將jsonstring打印出來 - (void)print:(NSString *)jsonString; @end @interface iOS : NSObject<JSObjectProtocol> @end
.m @implementation iOS #pragma mark -打印jsonString - (void)print:(NSString *)jsonString{ //打印的具體事件 }
2. 在網頁加載結束之後調用注冊iOS注冊
#pragma mark -網頁加載完畢,注冊ios對象,並且自動檢查打印機是否自動連接 -(void)webViewDidFinishLoad:(UIWebView *)webView{ //首先創建JSContext 對象(此處通過當前webView的鍵獲取到jscontext) //這個對象必須創建出來,否則會無法調用到協議裡的方法 iOS *ios = [[iOS alloc] init]; JSContext *context = [self.webView valueForKeyPath:@"documentView.webView.mainFrame.javaScriptContext"]; context[@"iOS"] = ios; }
3. 在js的點擊事件裡面類似下面這樣調用即可(下面這段代碼寫在對應的js代碼裡面,而非你的oc代碼裡面)
if (window["Android"] && window["Android"]["jsPrint"]) { var andPrint = window.Android.jsPrint(JSON.stringify(d)); } else if (window["iOS"] && window["iOS"]["print"]) { window["iOS"]["print"](JSON.stringify(d)); } else { this.alert.autoCloseTip("找不到打印方法!", 1000); }
以上就是關於iOS如何使用javascript代碼調用oc方法的全部內容,希望對大家學習IOS開發有所幫助。希望大家多多支持本站。