@ReactMethod
public void startActivityFromJS(String name, String params){
try{
Activity currentActivity = getCurrentActivity();
if(null!=currentActivity){
Class toActivity = Class.forName(name);
Intent intent = new Intent(currentActivity,toActivity);
intent.putExtra(“params”, params);
currentActivity.startActivity(intent);
}
}catch(Exception e){
throw new JSApplicationIllegalArgumentException(
"不能打开Activity : "+e.getMessage());
}
}
@ReactMethod
public void dataToJS(Callback successBack, Callback errorBack){
try{
Activity currentActivity = getCurrentActivity();
String result = currentActivity.getIntent().getStringExtra(“data”);
if (TextUtils.isEmpty(result)){
result = “没有数据”;
}
successBack.invoke(result);
}catch (Exception e){
errorBack.invoke(e.getMessage());
}
}
//注意:startActivityFromJS、dataToJS方法添加RN注解(@ReactMethod),否则该方法将不被添加到RN中
}
第三步,创建MyReactPackage类
实现ReactPackage接口暴露给RN调用,在createNativeModules里注册上一步添加的模块:
/**
- 注册模块
*/
public class MyReactPackage implements ReactPackage {
@Override
public List createNativeModules(ReactApplicationContext reactContext) {
return Arrays.asList(new MyIntentModule(reactContext));
}
@Override
public List createViewManagers(ReactApplicationContext reactContext) {
return Collections.emptyList();
}
}
第四步,在MainApplication中的getPackages方法中注册到ReactPackage中:
@Override
protected List getPackages() {
return Arrays.asList(
new MainReactPackage(),
new MyReactPackage()
);
}
第五步,接下来的工作便是RN的Index.js代码:
import React, { Component } from ‘react’;
import {
View,
NativeModules,
TouchableNativeFeedback,
ToastAndroid
} from ‘react-native’;
export default class App extends Component<{}> {
_onPressButton() {
console.log(“You tapped the button!”);
NativeModules
.IntentMoudle
.startActivityFromJS(“com.myreactdemo.MyActivity”, null);
}
render() {
return (
);
}
}
第六步,从Android跳转到RN页面
可以在rn中拿到activity跳转传递的值,值的传递跟普通activity之间的跳转没有差别:
[javascript] view plain copy
getData() {
NativeModules.IntentModule.dataToJS((msg) => {
console.log(msg);
let base = require(‘./constant’);
base.columnID = msg;
//ToastAndroid.show(‘JS界面:从Activity中传输过来的数据为:’ + base.columnID, ToastAndroid.SHORT);
},
(result) => {
ToastAndroid.show(‘JS界面:错误信息为:’ + result, ToastAndroid.SHORT);
})
}
拿到这个值之后存在了常量类里,就是通过这个常量来实现跳转到不同的界面,之后的事情就迎刃而解了:
[java] view plain copy
componentDidMount() {
let base = require(‘./constant’);
//ToastAndroid.show(base.columnID, ToastAndroid.SHORT);
let id = base.columnID;
if (id == “3”) {
const { navigator } = this.props;
if (navigator) {
navigator.push({
name: ‘secondPage’,
component: secondPage,
})
}
} if (id == “4”) {
const { navigator } = this.props;
if (navigator) {
navigator.push({
name: ‘otherPage’,
component: otherPage,
})
}
}
}
第七步,运行安装:
输入命令启动应用:
1.进入项目根目录:
cd MyReactDemo
2.运行:
react-native run-android
*如果设备没安装上AwesomeProject,可直接用Android studio或eclipse开发工具打开AwesomeProject文件里的Android项目,点击run运行安装即可。运行应用首先需要启动开发服务器(Packager)
最后
今天关于面试的分享就到这里,还是那句话,有些东西你不仅要懂,而且要能够很好地表达出来,能够让面试官认可你的理解,例如Handler机制,这个是面试必问之题。有些晦涩的点,或许它只活在面试当中,实际工作当中你压根不会用到它,但是你要知道它是什么东西。
最后在这里小编分享一份自己收录整理上述技术体系图相关的几十套腾讯、头条、阿里、美团等公司2021年的面试题,把技术点整理成了视频和PDF(实际上比预期多花了不少精力),包含知识脉络 + 诸多细节,由于篇幅有限,这里以图片的形式给大家展示一部分。
还有 高级架构技术进阶脑图、Android开发面试专题资料,高级进阶架构资料 帮助大家学习提升进阶,也节省大家在网上搜索资料的时间来学习,也可以分享给身边好友一起学习。
【Android核心高级技术PDF文档,BAT大厂面试真题解析】
【算法合集】
【延伸Android必备知识点】
【Android部分高级架构视频学习资源】
Android精讲视频领取学习后更加是如虎添翼!进军BATJ大厂等(备战)!现在都说互联网寒冬,其实无非就是你上错了车,且穿的少(技能),要是你上对车,自身技术能力够强,公司换掉的代价大,怎么可能会被裁掉,都是淘汰末端的业务Curd而已!现如今市场上初级程序员泛滥,这套教程针对Android开发工程师1-6年的人员、正处于瓶颈期,想要年后突破自己涨薪的,进阶Android中高级、架构师对你更是如鱼得水,赶快领取吧!
《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》,点击传送门,即可获取!
5)]
【Android部分高级架构视频学习资源】
Android精讲视频领取学习后更加是如虎添翼!进军BATJ大厂等(备战)!现在都说互联网寒冬,其实无非就是你上错了车,且穿的少(技能),要是你上对车,自身技术能力够强,公司换掉的代价大,怎么可能会被裁掉,都是淘汰末端的业务Curd而已!现如今市场上初级程序员泛滥,这套教程针对Android开发工程师1-6年的人员、正处于瓶颈期,想要年后突破自己涨薪的,进阶Android中高级、架构师对你更是如鱼得水,赶快领取吧!
《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》,点击传送门,即可获取!