RN與android簡(jiǎn)單通信(四)

本文主要介紹RN與android之間的通信固蚤,大神繞步
混合開發(fā)中,我們經(jīng)常會(huì)遇到各種各樣的通信問(wèn)題,比如java和C++之間的互相調(diào)用瘟滨,ok,閑話少說(shuō)能颁,我們直入主題杂瘸。

首先我們來(lái)實(shí)現(xiàn)一個(gè)簡(jiǎn)單功能:在js中點(diǎn)擊一個(gè)按鈕,傳遞一個(gè)字符串到native伙菊,然后在native端改變這個(gè)字符串败玉,并返回給js端,說(shuō)干就干镜硕,步驟如下

1.js中寫一個(gè)按鈕运翼,并且綁定點(diǎn)擊事件調(diào)用原生方法
2.寫一個(gè)Module,并且添加到Package
3.native接受傳遞過(guò)來(lái)的參數(shù)兴枯,處理參數(shù)回調(diào)回js

接下來(lái)血淌,我們會(huì)逐一實(shí)現(xiàn)上述步驟
1.在js里添加如下代碼

'use strict'
import React, { Component} from 'react';
import { AsyncStorage,NativeModules,ToastAndroid } from 'react-native';
import {
  AppRegistry,
  StyleSheet,
  Text,
  Image,
  View
} from 'react-native';

let title = 'React Native界面';

export default class YRNTest extends Component {
    /**
    * Callback 通信方式
    */
    callbackComm(msg) {
        NativeModules.CommonModule.rnCallNativeFromCallback(msg,(result) => {
             ToastAndroid.show("CallBack收到消息:" + result, ToastAndroid.SHORT);
        })
    }

    /**
    * Promise 通信方式
    */
    promiseComm(msg) {
        NativeModules.CommonModule.rnCallNativeFromPromise(msg).then(
            (result) =>{
                ToastAndroid.show("Promise收到消息:" + result, ToastAndroid.SHORT)
            }
        ).catch((error) =>{console.log(error)});
    }

  render() {
    return (
      <View style={styles.container}>
        <Text style={styles.welcome} >
            {title}
        </Text>
        <Text style={styles.welcome} onPress={this.callbackComm.bind(this,'你好啊,android')}>
             Callback通信方式
        </Text>
        <Text style={styles.welcome} onPress={this.promiseComm.bind(this,'你好啊,android')}>
             Promise通信方式
        </Text>
      </View>
    );
  }
}

const styles = StyleSheet.create({
  container: {
    flex: 1,
    justifyContent: 'center',
    alignItems: 'center',
    backgroundColor: '#FFFFFF',
  },
  welcome: {
    fontSize: 20,
    textAlign: 'center',
    margin: 10,
  }
});

AppRegistry.registerComponent('YRNTest', () => YRNTest);

注意這里的NativeModules.CommonModule.rnCallNativeFromCallback悠夯,我們js調(diào)用Native一般都是采用的NativeModules.模塊名稱.模塊方法名稱
2.定義Module類癌淮,繼承ReactContextBaseJavaModule,在Module類中,我們定義一些交互的方法

public class CommonModule extends ReactContextBaseJavaModule {
    public CommonModule(ReactApplicationContext reactContext) {
        super(reactContext);
    }

  /**
     * RN調(diào)用Native的方法
    * Callback方式回調(diào)
     */
    @ReactMethod
    public void rnCallNativeFromCallback(String param, Callback callback) {
        String a = "嘖嘖嘖:" + param;
        if (callback != null)
            callback.invoke(a);
    }

 /**
     * RN調(diào)用Native的方法
    * Promise方式回調(diào)
     */
    @ReactMethod
    public void rnCallNativeFromPromise(String msg, Promise promise) {
        String result = "嘖嘖嘖:" + msg;
        promise.resolve(result);
    }

    @Override
    public String getName() {
        return "CommonModule";
    }
}

注意這里的getName方法返回的字符串要與上面的NativeModules.模塊名稱.模塊方法名稱里的模塊名稱保持一致沦补。rnCallNativeFromCallback要與上面的NativeModules.模塊名稱.模塊方法名稱里的模塊方法名稱保持一致乳蓄,并且在rnCallNativeFromCallback方法上還需要加上@ReactMethod注解

定義Package,實(shí)現(xiàn)ReactPackage接口夕膀,在createNativeModules方法里把自定義的CommonModule添加進(jìn)去

public class CommPackage implements ReactPackage {
    @Override
    public List<NativeModule> createNativeModules(ReactApplicationContext reactContext) {
        List<NativeModule> modules = new ArrayList<>();
        modules.add(new CommonModule(reactContext));
        return modules;
    }

    @Override
    public List<ViewManager> createViewManagers(ReactApplicationContext reactContext) {
        return null;
    }
}

最后在MyApplication里添加自定義的Package
1525320513500.jpg

3.這里只介紹Native回調(diào)回js的兩種方式:CallBack和Promise

首先看一下Callback方式虚倒,通過(guò)callback的invoke方法把參數(shù)帶回去

    @ReactMethod
    public void rnCallNativeFromCallback(String param, Callback callback) {
        String a = "嘖嘖嘖:" + param;
        if (callback != null)
            callback.invoke(a);
    }

再來(lái)看下Promise方式,通過(guò)Promise的resolve方法把參數(shù)帶回去

 @ReactMethod
    public void rnCallNativeFromPromise(String msg, Promise promise) {
        String result = "嘖嘖嘖:" + msg;
        promise.resolve(result);
    }
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末产舞,一起剝皮案震驚了整個(gè)濱河市魂奥,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌庞瘸,老刑警劉巖捧弃,帶你破解...
    沈念sama閱讀 216,324評(píng)論 6 498
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異擦囊,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)嘴办,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,356評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門瞬场,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人涧郊,你說(shuō)我怎么就攤上這事贯被。” “怎么了妆艘?”我有些...
    開封第一講書人閱讀 162,328評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵彤灶,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我批旺,道長(zhǎng)幌陕,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,147評(píng)論 1 292
  • 正文 為了忘掉前任汽煮,我火速辦了婚禮搏熄,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘暇赤。我一直安慰自己心例,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,160評(píng)論 6 388
  • 文/花漫 我一把揭開白布鞋囊。 她就那樣靜靜地躺著止后,像睡著了一般。 火紅的嫁衣襯著肌膚如雪溜腐。 梳的紋絲不亂的頭發(fā)上译株,一...
    開封第一講書人閱讀 51,115評(píng)論 1 296
  • 那天瓜喇,我揣著相機(jī)與錄音,去河邊找鬼古戴。 笑死欠橘,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的现恼。 我是一名探鬼主播肃续,決...
    沈念sama閱讀 40,025評(píng)論 3 417
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼叉袍!你這毒婦竟也來(lái)了始锚?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 38,867評(píng)論 0 274
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤喳逛,失蹤者是張志新(化名)和其女友劉穎瞧捌,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體润文,經(jīng)...
    沈念sama閱讀 45,307評(píng)論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡姐呐,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,528評(píng)論 2 332
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了典蝌。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片曙砂。...
    茶點(diǎn)故事閱讀 39,688評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖骏掀,靈堂內(nèi)的尸體忽然破棺而出鸠澈,到底是詐尸還是另有隱情,我是刑警寧澤截驮,帶...
    沈念sama閱讀 35,409評(píng)論 5 343
  • 正文 年R本政府宣布笑陈,位于F島的核電站,受9級(jí)特大地震影響葵袭,放射性物質(zhì)發(fā)生泄漏涵妥。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,001評(píng)論 3 325
  • 文/蒙蒙 一眶熬、第九天 我趴在偏房一處隱蔽的房頂上張望妹笆。 院中可真熱鬧,春花似錦娜氏、人聲如沸拳缠。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,657評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)窟坐。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間哲鸳,已是汗流浹背臣疑。 一陣腳步聲響...
    開封第一講書人閱讀 32,811評(píng)論 1 268
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留徙菠,地道東北人讯沈。 一個(gè)月前我還...
    沈念sama閱讀 47,685評(píng)論 2 368
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像婿奔,于是被迫代替她去往敵國(guó)和親缺狠。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,573評(píng)論 2 353

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

  • Android 自定義View的各種姿勢(shì)1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 172,070評(píng)論 25 707
  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理萍摊,服務(wù)發(fā)現(xiàn)挤茄,斷路器,智...
    卡卡羅2017閱讀 134,651評(píng)論 18 139
  • 自從Facebook提出了react之后冰木,這個(gè)框架的關(guān)注度一直居高不下穷劈,它所引入的一些東西還是值得學(xué)習(xí),比如組件化...
    樹下老男孩閱讀 12,356評(píng)論 10 56
  • 身著旗袍爬假山踊沸, 山頂俯觀水連天歇终。 近看景色美如畫, 遠(yuǎn)觀猶在畫中間逼龟。
    往事如煙胖婆婆閱讀 468評(píng)論 10 13
  • 一直都有寫東西的想法练湿,也許沒(méi)有寫作的天賦,無(wú)法寫出動(dòng)人的詞句审轮,也無(wú)法說(shuō)出多么深刻的哲理。但我只是想記錄我的生活辽俗,記...
    Betty來(lái)自未來(lái)閱讀 258評(píng)論 0 0