摘要:為函數(shù)名稱,設(shè)置這個(gè)主要是為了將多個(gè)暴露方法統(tǒng)一管理。調(diào)用如下原生如何直接調(diào)用有時(shí)候單原生觸發(fā)了某一操作時(shí),應(yīng)用需要響應(yīng),然后執(zhí)行相應(yīng)的操作。
1. 原生暴露方法(這里myclass為暴露原生方法模塊) //myclass.h (所有提供給RN使用的方法都得繼承RCTBridgeModule類) #import#import "RCTBridgeModule.h" @interface MyClass : NSObject @end //myclass.m #import "MyClass.h" #import "RCTBridge.h" @implementation MyClass @synthesize bridge = _bridge; //暴露模塊 RCT_EXPORT_MODULE(); //暴露方法(這里暴露了addEvent方法。 actionType為函數(shù)名稱,設(shè)置這個(gè)主要是為了將多個(gè)暴露方法統(tǒng)一管理。propertyDic為RN調(diào)用時(shí)傳入的參數(shù)) RCT_EXPORT_METHOD(addEvent:(NSString *)actionType actionName:(NSString *)actionName propertyDic:(NSDictionary*)propertyDic callbackEvents:(RCTResponseSenderBlock)callback) { if ([actionType isEqualToString:@"Nav"]) { KTVListenWorkVC* vc = [[KTVListenWorkVC alloc] init]; vc.opusId = [propertyDic[@"opusId"] longLongValue]; [[KGMainViewController shareMainViewController] pushViewControllerToKGNavigation:vc animated:YES]; }else if([actionType isEqualToString:@"http"]){ KTVHttpPostRequstData * postHttpRequstData = [[KTVHttpPostRequstData alloc] init]; postHttpRequstData.requstDic = propertyDic; callback(@[[postHttpRequstData toRequstURL]]); } }
2. js調(diào)用原生方法 import {NativeModules} from "react-native"; var nativeMethod = NativeModules.MyClass; //第一個(gè)參數(shù)為原生暴露的方法名, 第二個(gè)參數(shù)隨便寫, 第三個(gè)是回調(diào)函數(shù)(data為執(zhí)行原生方法后返回的參數(shù)) nativeMethod.addEvent("http", "aaaa", function(data){ callback() }
//其實(shí)RN跳轉(zhuǎn)原生的原理比較簡單,在ios中就是初始化一個(gè)類,也就是上面暴露的Nav方法。 js調(diào)用如下 nativeMethod.addEvent("Nav", "aaaa", {"opusId": this.props.opusId}, function(){})
有時(shí)候單原生觸發(fā)了某一操作時(shí),RN應(yīng)用需要響應(yīng),然后執(zhí)行相應(yīng)的操作。這里分兩個(gè)步驟:
1.RN注冊監(jiān)聽事件 //首頁導(dǎo)入監(jiān)聽事件模塊并注冊監(jiān)聽事件(這里其實(shí)有多個(gè)模塊可以調(diào)用,詳細(xì)可以看RCTEventDispatcher文件源碼) import RCTNativeAppEventEmitter from "RCTNativeAppEventEmitter"; //這個(gè)方法是單城市選擇改變時(shí),顯示的數(shù)據(jù)實(shí)時(shí)改變 RCTNativeAppEventEmitter.addListener("changeCityCode",function(result){ ...... })
2 原生派發(fā)事件(在myclass尾部加入下面代碼,并導(dǎo)入RCTEventDispatcher模塊) #import "RCTEventDispatcher.h" //重寫bridge方法 - (void)setBridge:(RCTBridge *)bridge { _bridge = bridge; [[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(receiveCityChangeNotifaction:) name:KTV_CHANGE_CITY_NOTYFY object:nil]; } - (void)receiveCityChangeNotifaction: (NSNotification *)notify { NSDictionary * info = notify.userInfo; KTVCityModel * city = [info objectForKey:@"selectedCity"]; if (city && [city isKindOfClass:[KTVCityModel class]]) { NSDictionary * notifyInfo = [NSDictionary dictionaryWithObjectsAndKeys: [NSNumber numberWithInteger: city.cityCode], @"citycode", nil]; [self.bridge.eventDispatcher sendAppEventWithName:@"changeCityCode" body:notifyInfo]; } } @end
應(yīng)用場景如下,上面紅色框部分為原生的,RN應(yīng)用是嵌入到原生試圖的,當(dāng)原生改變城市時(shí),RN的數(shù)據(jù)需要重新渲染。
后續(xù)會(huì)繼續(xù)補(bǔ)充,如有錯(cuò)誤的地方,還請小伙伴們指出一起交流,謝謝~
源碼地址:點(diǎn)這里
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/90873.html
摘要:項(xiàng)目地址傳送門內(nèi)附項(xiàng)目預(yù)覽環(huán)境配置客戶端的安裝調(diào)試工具依賴環(huán)境探坑總結(jié)無法渲染文本需使用不支持富文本,需單獨(dú)封裝不支持,層級(jí)靠后優(yōu)先表達(dá)式需使用數(shù)組形式,否則會(huì)報(bào)錯(cuò)無法簡寫例不支持,需各寫屬性不支持操作原生滑動(dòng)事件不支持嵌套和 項(xiàng)目地址 git傳送門(內(nèi)附項(xiàng)目預(yù)覽) Weex環(huán)境配置 npm install -g weex npm install -g weexpack # weex...
閱讀 2513·2021-10-14 09:42
閱讀 1151·2021-09-22 15:09
閱讀 3557·2021-09-09 09:33
閱讀 3037·2021-09-07 09:59
閱讀 3652·2021-09-03 10:34
閱讀 3555·2021-07-26 22:01
閱讀 2836·2019-08-30 13:06
閱讀 1217·2019-08-30 10:48