Object-C與JavaScript相互調(diào)用及傳值方式

最近遇到一個Object-C與JavaScript相互調(diào)用的問題處理方式如下:

注意:一定要寫對H5中的方法名

舉例說明:

  1. ViewController.h文件
#import <UIKit/UIKit.h>
#import <JavaScriptCore/JavaScriptCore.h>
@protocol JSObjcDelegate <JSExport>
//對象調(diào)用的JavaScript方法删豺,必須聲明!7兑ā楚殿!
- (void)call1;
- (void)getCall:(NSString *)callString;
@end
@interface ViewController : UIViewController<UIWebViewDelegate,JSObjcDelegate>
@property (nonatomic, strong) JSContext *jsContext;
@property (strong, nonatomic)  UIWebView *webView;
@end
  1. ViewController.m文件
#import "ViewController.h"
@interface ViewController ()
@property(nonatomic,copy)NSString * JSName;
@end

@implementation ViewController
- (void)viewDidLoad {
    [super viewDidLoad];
    self.webView = [[UIWebView alloc]initWithFrame:CGRectMake(0, 20, [UIScreen mainScreen].bounds.size.width, [UIScreen mainScreen].bounds.size.height)];
    self.webView.delegate = self;
    //從本地加載html文件
    NSString* path = [[NSBundle mainBundle] pathForResource:@"index" ofType:@"html"];
    NSURL* url = [NSURL fileURLWithPath:path];
    NSURLRequest* request = [NSURLRequest requestWithURL:url] ;
    [self.webView loadRequest:request];
    [self.view addSubview:self.webView];
}

//JavaScript的tianbai是一個對象,充當(dāng)原生應(yīng)用和web頁面之間的一個橋梁笋轨。用來調(diào)用方法

//webview加載完成調(diào)用代理

- (void)webViewDidFinishLoad:(UIWebView *)webView {
    // 設(shè)置javaScriptContext上下文
    self.jsContext = [webView valueForKeyPath:@"documentView.webView.mainFrame.javaScriptContext"];
    //將tianbai對象指向自身
    self.jsContext[@"baoming"] = self;
    self.jsContext.exceptionHandler = ^(JSContext *context, JSValue *exceptionValue) {
        context.exception = exceptionValue;
        NSLog(@"異常信息:%@", exceptionValue);
    };
}
//將對象指向自身后穿扳,如果調(diào)用 tianbai.call() 會響應(yīng)下面的方法怀泊,OC方法中調(diào)用js中的Callback方法躯畴,并傳值

- (void)call1{
    NSString * str = self.JSName;
    JSValue *openLogin = self.jsContext[str];
       
    //獲取包名
       NSDictionary *infoDictionary = [[NSBundle mainBundle] infoDictionary];
       NSString * bildName = [infoDictionary objectForKey:@"CFBundleDisplayName"];
   //傳值給web端
        [openLogin callWithArguments:@[bildName]];
}


//將對象指向自身后民鼓,如果調(diào)用 tianbai.getCall(callInfo) 會響應(yīng)下面的方法,OC方法中僅調(diào)用JavaScript中的alerCallback方法

- (void)getCall:(NSString *)callString{
    self.JSName = callString;
    [self call1];
    NSLog(@"Get:%@", callString);
    // 成功回調(diào)JavaScript的方法Callback
//    JSValue *Callback = self.jsContext[@"alerCallback"];
//    [Callback callWithArguments:nil];
}

//將對象指向自身后蓬抄,還可以向html注入js
- (void)alert{
    // 直接添加提示框
    NSString *str = @"alert('OC添加JS提示成功')";
    [self.jsContext evaluateScript:str];
}


- (void)didReceiveMemoryWarning {
    [super didReceiveMemoryWarning];
    // Dispose of any resources that can be recreated.
}

@end

3.HTML文件

<!DOCTYPE html>
<html>
    <head>
        <meta charset="UTF-8">
    </head>
    <body>
        <div style="margin-top: 20px">
            <h2>JS與OC交互</h2>
            <input type="button" value="喚起本地方法(call)" onclick="baoming.call()">
        </div>
        <div>
            <input type="button" value="喚起getCall:(NSString *)callString傳值" onclick="call()">
        </div>
        <div>
            <input type="button" value="包名" onclick="call1()">
                </div>
        <script>
            

        var call1 = function()
        {
            var callInfo = {"jianshu": "http://www.reibang.com/users/55c8fdc3c6e7/latest_articles", "ceshi": "data111"};
                            tianbai.getCall(callInfo);

        }
        
        
        var Callback = function(str)
        {
            alert(str);
        }
        
        var openLogin = function(str)
        {
            alert(str);
        }
        
        var alerCallback = function()
        {
            alert('成功');
        }
        </script>
    </body>
</html>

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末丰嘉,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子嚷缭,更是在濱河造成了極大的恐慌饮亏,老刑警劉巖,帶你破解...
    沈念sama閱讀 217,277評論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件阅爽,死亡現(xiàn)場離奇詭異路幸,居然都是意外死亡,警方通過查閱死者的電腦和手機优床,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,689評論 3 393
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來誓焦,“玉大人胆敞,你說我怎么就攤上這事≡游埃” “怎么了移层?”我有些...
    開封第一講書人閱讀 163,624評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長赫粥。 經(jīng)常有香客問我观话,道長,這世上最難降的妖魔是什么越平? 我笑而不...
    開封第一講書人閱讀 58,356評論 1 293
  • 正文 為了忘掉前任频蛔,我火速辦了婚禮灵迫,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘晦溪。我一直安慰自己瀑粥,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 67,402評論 6 392
  • 文/花漫 我一把揭開白布三圆。 她就那樣靜靜地躺著狞换,像睡著了一般。 火紅的嫁衣襯著肌膚如雪舟肉。 梳的紋絲不亂的頭發(fā)上修噪,一...
    開封第一講書人閱讀 51,292評論 1 301
  • 那天,我揣著相機與錄音路媚,去河邊找鬼黄琼。 笑死,一個胖子當(dāng)著我的面吹牛磷籍,可吹牛的內(nèi)容都是我干的适荣。 我是一名探鬼主播,決...
    沈念sama閱讀 40,135評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼院领,長吁一口氣:“原來是場噩夢啊……” “哼弛矛!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起比然,我...
    開封第一講書人閱讀 38,992評論 0 275
  • 序言:老撾萬榮一對情侶失蹤丈氓,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后强法,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體万俗,經(jīng)...
    沈念sama閱讀 45,429評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,636評論 3 334
  • 正文 我和宋清朗相戀三年饮怯,在試婚紗的時候發(fā)現(xiàn)自己被綠了闰歪。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,785評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡蓖墅,死狀恐怖库倘,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情论矾,我是刑警寧澤教翩,帶...
    沈念sama閱讀 35,492評論 5 345
  • 正文 年R本政府宣布,位于F島的核電站贪壳,受9級特大地震影響饱亿,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,092評論 3 328
  • 文/蒙蒙 一彪笼、第九天 我趴在偏房一處隱蔽的房頂上張望钻注。 院中可真熱鬧,春花似錦杰扫、人聲如沸队寇。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,723評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽佳遣。三九已至,卻和暖如春凡伊,著一層夾襖步出監(jiān)牢的瞬間零渐,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,858評論 1 269
  • 我被黑心中介騙來泰國打工系忙, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留诵盼,地道東北人。 一個月前我還...
    沈念sama閱讀 47,891評論 2 370
  • 正文 我出身青樓银还,卻偏偏與公主長得像风宁,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子蛹疯,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,713評論 2 354

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

  • mean to add the formatted="false" attribute?.[ 46% 47325/...
    ProZoom閱讀 2,696評論 0 3
  • 繼兩個星期的感冒頹廢后重新跑步捺弦!昨天前天都跑了十圈饮寞,今天體育課,室友很頹廢的說不跑列吼,運動量有點大幽崩,那就不然咯。ps...
    Taunt閱讀 109評論 0 0
  • 今日體驗:早上一個老客戶大姐的自由光要過來保養(yǎng).還有要訂兩個軸承提前準(zhǔn)備好.這樣也節(jié)省時間大老遠過來的.中午到店更...
    京心達何海港閱讀 142評論 0 0
  • 文|婕然布桐 在《PET父母效能訓(xùn)練手冊》一書中蹄溉,提到了“你-信息”和“我-信息”的說法。這是書中教授給我們的一種...
    相望街角的幸福閱讀 1,288評論 0 0
  • 陰雨纏綿繞君山香浩, 翠林搖曳換新顏类缤。 百鳥歸巢避時雨臼勉, 唯吾獨處感秋寒邻吭。
    踏浪散人閱讀 376評論 0 0