使用runtime 實(shí)現(xiàn)weex 跳轉(zhuǎn)原生頁(yè)面
一、簡(jiǎn)述
最近項(xiàng)目組打算引入weex,并選定了一個(gè)頁(yè)面進(jìn)行試水。頁(yè)面很簡(jiǎn)單,主要是獲取數(shù)據(jù)渲染頁(yè)面,并可以跳轉(zhuǎn)到指定的頁(yè)面。跟之前使用RN 相比,weex 確實(shí)要簡(jiǎn)單很多。從下圖中我們可以看到,weex 頁(yè)面需要跳轉(zhuǎn)到原生頁(yè)面,并且跳轉(zhuǎn)到哪個(gè)頁(yè)面我們可能并不能寫死。也就是說只要原生頁(yè)面之前項(xiàng)目中寫過了,那么理論上來說使用weex 可以任意調(diào)用。那么問題來了,我原來的頁(yè)面可能只知道名字,我怎么為那個(gè)頁(yè)面?zhèn)髦的??比如有個(gè)頁(yè)面orderDetailVC ,跳轉(zhuǎn)時(shí)需要傳入orderId,即orderDetailVC.orderId = @"123";

二、思考
可能最直接的想法就是直接原生給weex 提供一個(gè)方法,讓weex 傳入orderId,然后再push。但是如果明天我們需要跳轉(zhuǎn)到另一個(gè)頁(yè)面merchantDetailVC呢?它需要的不是orderId了,可能是一個(gè)merchantId,甚至更多參數(shù)。那怎么才能實(shí)現(xiàn)任意跳轉(zhuǎn)呢?我的想法是,項(xiàng)目是我寫的,需要跳轉(zhuǎn)到哪個(gè)類,那么這個(gè)類名我肯定是清楚的,并且這個(gè)類應(yīng)該需要什么參數(shù)我也是清楚的。只不過我可能不知道怎么用weex 把它參數(shù)傳過去而已。如果知道了類名就意味著我知道了這個(gè)類,我能找到這個(gè)類,那么我就知道這個(gè)類有哪些屬性了,這個(gè)類的所有屬性我都能拿到,只不過有些是我需要給它賦值的,有些是不需要處理的。
三、實(shí)現(xiàn)
整體的思路是:原生給weex 提供一個(gè)通用的跳轉(zhuǎn)方法。參數(shù)是類名和屬性字典。
//控制器相關(guān) /* vcName: 頁(yè)面名稱 param:頁(yè)面所需參數(shù)(如原來的頁(yè)面需要傳遞小區(qū)id,工單號(hào)等等,字典形式傳過去,key 與頁(yè)面所需參數(shù)名稱一致即可。 */ -(void)pushViewController:(NSString *)vcName param:(NSDictionary *)param; /* 將APP 當(dāng)前展示的頁(yè)面pop */ -(void)popViewController; /* vcName: 頁(yè)面名稱 param:頁(yè)面所需參數(shù)(如原來的頁(yè)面需要傳遞小區(qū)id,工單號(hào)等等,字典形式傳過去,key 與頁(yè)面所需參數(shù)名稱一致即可。 */ -(void)presentViewController:(NSString *)vcName param:(NSDictionary *)param finish:(WXModuleCallback)callback; /* 將APP 當(dāng)前展示的頁(yè)面dismiss */ -(void)dismissViewController:(WXModuleCallback)callback;
提供方法后weex 可以這樣調(diào)用:

確定了方案之后,剩下唯一的事情就是如何實(shí)現(xiàn)給weex 提供的方法。代碼如下:
-(void)pushViewController:(NSString *)vcName param:(NSDictionary *)param{
//獲取類
Class vcClass = NSClassFromString(vcName);
if (vcClass == nil) {
return;
}
BaseViewController *vc = [[vcClass alloc] init];
vc.hidesBottomBarWhenPushed = YES;
//屬性數(shù)量
unsigned int count = 0;
//獲取屬性列表
objc_property_t *plist = class_copyPropertyList(vcClass, &count);
for (int i = 0; i<count; i++) {
//取出屬性
objc_property_t property = plist[i];
//取出屬性名稱
NSString *propertyName = [NSString stringWithUTF8String:property_getName(property)];
//以這個(gè)屬性名稱作為key ,查看傳入的字典里是否有這個(gè)屬性的value
if (param[propertyName]) {
[vc setValue:param[propertyName] forKey:propertyName];
}
}
//釋放
free(plist);
//獲取當(dāng)前頁(yè)面控制器
/*
獲取當(dāng)前頁(yè)面控制器是根據(jù)響應(yīng)鏈獲取的。
*/
UIViewController *currentVC = [Utils getCurrentVC];
if ([currentVC isKindOfClass:[UINavigationController class]]) {
[(UINavigationController *)currentVC pushViewController:vc animated:YES];
}else{
[currentVC.navigationController pushViewController:vc animated:YES];
}
}
經(jīng)過小規(guī)模自測(cè)發(fā)現(xiàn)是可以實(shí)現(xiàn)需求的。但是由于實(shí)現(xiàn)時(shí)間不長(zhǎng),可能會(huì)有不足之處,請(qǐng)謹(jǐn)慎參考。如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
相關(guān)文章
Android側(cè)滑菜單控件DrawerLayout使用詳解
這篇文章主要為大家詳細(xì)介紹了Android側(cè)滑菜單控件DrawerLayout的使用,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-12-12
Android獲取本機(jī)電話號(hào)碼的簡(jiǎn)單方法
Android獲取本機(jī)電話號(hào)碼的簡(jiǎn)單方法,需要的朋友可以參考一下2013-05-05
Flutter如何完成路由攔截,實(shí)現(xiàn)權(quán)限管理
本篇介紹了利用 Fluro 路由管理實(shí)現(xiàn)路由權(quán)限攔截的兩種方式,兩種方式各有好處,使用過程中可以根據(jù)實(shí)際情況決定使用哪一種方法。2021-06-06
Android頁(yè)面之間進(jìn)行數(shù)據(jù)回傳的方法分析
這篇文章主要介紹了Android頁(yè)面之間進(jìn)行數(shù)據(jù)回傳的方法,結(jié)合實(shí)例形式分析了Android頁(yè)面之間進(jìn)行數(shù)據(jù)的傳遞與處理技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2016-06-06
Android進(jìn)程間使用Intent進(jìn)行通信
Android進(jìn)程間通信(IPC,Inter-Process Communication)底層采用的是 Binder 機(jī)制,具體到應(yīng)用層有網(wǎng)友根據(jù)安卓四大組件將進(jìn)程間通信方式分為對(duì)應(yīng)的四種方式 Activity, Broadcast, ContentProvider, Service2023-02-02
Android TimerTask 的簡(jiǎn)單應(yīng)用及注意事項(xiàng)
這篇文章主要介紹了Android TimerTask 的簡(jiǎn)單應(yīng)用及注意事項(xiàng)的相關(guān)資料,需要的朋友可以參考下2017-06-06

