[React Native Android 安利系列]原生小知识(创建activity并跳转)

欢迎大家收看react-native-android系列教程,跟着本系列教程学习,可以熟练掌握react-native-android的开发,你值得拥有
https://segmentfault.com/blog...

react-native毕竟也要有一些原生的知识,这里我们先学习一下原生android创建activity,并跳转的过程。这有助于我们的前端开发同学,掌握一下android姿势。本实验的view采用react进行渲染,也为后续的学习做下铺垫。如果已经有了相关知识的同学,直接跳过即可。

1. android的activity跳转(原生基础小知识)

在我们做js调用activity之前,先复习一下简单的android开发的知识---两个activity之间的跳转。
对于没有开发过android app的同学来说,需要先了解一下android的基础知识。android中有一个比较重要的组件--activity,是用于显示View的。比如,我们利用react创建的最简单的app,当我们一开始打开app的时候,其实就进入了一个主的activity,由其渲染我们的主界面,在这里,可以简单的理解activity为浏览器中的一个tab(可能并不严谨,不过对前端开发同学来说,可能更容易理解)。
两个activity之间,可以互相跳转(就像浏览器中的tab可以互相切换),我们来试试做两个activity,并让它们互相跳转(就像看到页面跳转那样的开心),这样我们就能更快的理解activity了。

1.1 新建activity

这里,我们利用之前构建的项目--helloReact来继续我们的旅途。
在这个项目中,我们看到了一个已经存在的activity,就是我们的主activity(如图1.1.1)。

图1.1.1
接下来,我们新建一个activity,在com.hellowreact下(与MainActivity.java放在一起即可),右键点击文件夹,并选择new->java Class(图1.1.2)

图1.1.2
这里我们起名为DetailActivity

图1.1.3
代码直接从MainActivity中复制过来即可,并将getMainComponentName的返回值略作修改,改为"detail"

package com.hellowreact;

import com.facebook.react.ReactActivity;
import com.facebook.react.ReactPackage;
import com.facebook.react.shell.MainReactPackage;

import java.util.Arrays;
import java.util.List;

/**
 * Created by baidu on 16/6/8.
 */
public class DetailActivity extends ReactActivity {

    /**
     * Returns the name of the main component registered from JavaScript.
     * This is used to schedule rendering of the component.
     */
    @Override
    protected String getMainComponentName() {
        return "detail";
    }

    /**
     * Returns whether dev mode should be enabled.
     * This enables e.g. the dev menu.
     */
    @Override
    protected boolean getUseDeveloperSupport() {
        return BuildConfig.DEBUG;
    }

    /**
     * A list of packages used by the app. If the app uses additional views
     * or modules besides the default ones,add more packages here.
     */
    @Override
    protected List<ReactPackage> getPackages() {
        return Arrays.<ReactPackage>asList(
                new MainReactPackage()
        );
    }
}

1.2 注册新的activity

请注意,我们新建的activity需要在AndroidManifest.xml中进行注册,AndroidManifest.xml位于app/manifests/下。

图1.2.1
我们打开AndroidManifest.xml,如图,可以看到其中已经有了一个叫MainActivity的activity

图1.2.2
我们在其中再添加一项,如图1.2.3

<activity android:name=".DetailActivity" />


图1.2.3

1.3 为新的activity添加渲染的view

我们有了新的activity,也就要添加一个渲染的view。打开项目中的index.android.js,新建一个react组件,并将其注册

class detail extends Component {
    constructor(props) {
        super(props);
    }   

    render() {
        return <View>
            <Text>detail!!!</Text>
        </View>;
    }   
}
AppRegistry.registerComponent('detail',() => detail);

至此,我们的view也有了。

1.4 先来看看我们新做的activity

为了早点看到效果,我们先把新制作的activity作为主要启动的activity。只需改写AndroidManifest.xml即可。

<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.hellowreact"
    android:versionCode="1"
    android:versionName="1.0">

    <uses-permission android:name="android.permission.INTERNET" />
    <uses-permission android:name="android.permission.SYSTEM_ALERT_WINDOW"/>

    <uses-sdk
        android:minSdkVersion="16"
        android:targetSdkVersion="22" />

    <application
      android:allowBackup="true"
      android:label="@string/app_name"
      android:icon="@mipmap/ic_launcher"
      android:theme="@style/AppTheme">
      <activity
        android:name=".MainActivity"
        android:label="@string/app_name"
        android:configChanges="keyboard|keyboardHidden|orientation|screenSize">
      </activity>
      <activity android:name="com.facebook.react.devsupport.DevSettingsActivity" />
        <activity android:name=".DetailActivity">
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />
                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>

    </application>

</manifest>

我们吧intent-filter从MainActivity中提出,并放到了DetailActivity中去。
让我们重装一下应用,于是我们就看到了新的activity,并看到了新增加的react组件渲染到了其上(如图1.4.1)。

图1.4.1

1.5 开始写activity之间的跳转

看过了新添加的activity之后,让我们先把AndroidManifest.xml给改回去。这样我们的启动界面就又是我们的列表啦(如图1.5.1)

图1.5.1
我们在MainActivity中,添加对于onBackPressed的重写(当返回键按下的时候)

public class MainActivity extends ReactActivity {

    @Override
    public void onBackPressed() {
        super.onBackPressed();
        Intent intent = new Intent(this,DetailActivity.class);
        startActivity(intent);
    }

    ........

当用户,按下返回键的时候,跳转到我们的DetailActivity中去。
重新Run一下app,我们看到了列表页,点击返回按钮的时候(如图1.5.2),我们看到跳转到了DetailActivity里面去,大功告成(如图1.5.3)

图1.5.2

图1.5.3

怎么样,是不是和页面跳转一样简单呢?

本文中相关例子,可以在此找到:
https://github.com/houyu01/re...

既然了解了原生知识,我们下一节将利用本节学到的原生知识,使用js去调用。这样双剑合璧,便可以更加高效的开发react-native应用啦~

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


react 中的高阶组件主要是对于 hooks 之前的类组件来说的,如果组件之中有复用的代码,需要重新创建一个父类,父类中存储公共代码,返回子类,同时把公用属性...
我们上一节了解了组件的更新机制,但是只是停留在表层上,例如我们的 setState 函数式同步执行的,我们的事件处理直接绑定在了 dom 元素上,这些都跟 re...
我们上一节了解了 react 的虚拟 dom 的格式,如何把虚拟 dom 转为真实 dom 进行挂载。其实函数是组件和类组件也是在这个基础上包裹了一层,一个是调...
react 本身提供了克隆组件的方法,但是平时开发中可能很少使用,可能是不了解。我公司的项目就没有使用,但是在很多三方库中都有使用。本小节我们来学习下如果使用该...
mobx 是一个简单可扩展的状态管理库,中文官网链接。小编在接触 react 就一直使用 mobx 库,上手简单不复杂。
我们在平常的开发中不可避免的会有很多列表渲染逻辑,在 pc 端可以使用分页进行渲染数限制,在移动端可以使用下拉加载更多。但是对于大量的列表渲染,特别像有实时数据...
本小节开始前,我们先答复下一个同学的问题。上一小节发布后,有小伙伴后台来信问到:‘小编你只讲了类组件中怎么使用 ref,那在函数式组件中怎么使用呢?’。确实我们...
上一小节我们了解了固定高度的滚动列表实现,因为是固定高度所以容器总高度和每个元素的 size、offset 很容易得到,这种场景也适合我们常见的大部分场景,例如...
上一小节我们处理了 setState 的批量更新机制,但是我们有两个遗漏点,一个是源码中的 setState 可以传入函数,同时 setState 可以传入第二...
我们知道 react 进行页面渲染或者刷新的时候,会从根节点到子节点全部执行一遍,即使子组件中没有状态的改变,也会执行。这就造成了性能不必要的浪费。之前我们了解...
在平时工作中的某些场景下,你可能想在整个组件树中传递数据,但却不想手动地通过 props 属性在每一层传递属性,contextAPI 应用而生。
楼主最近入职新单位了,恰好新单位使用的技术栈是 react,因为之前一直进行的是 vue2/vue3 和小程序开发,对于这些技术栈实现机制也有一些了解,最少面试...
我们上一节了了解了函数式组件和类组件的处理方式,本质就是处理基于 babel 处理后的 type 类型,最后还是要处理虚拟 dom。本小节我们学习下组件的更新机...
前面几节我们学习了解了 react 的渲染机制和生命周期,本节我们正式进入基本面试必考的核心地带 -- diff 算法,了解如何优化和复用 dom 操作的,还有...
我们在之前已经学习过 react 生命周期,但是在 16 版本中 will 类的生命周期进行了废除,虽然依然可以用,但是需要加上 UNSAFE 开头,表示是不安...
上一小节我们学习了 react 中类组件的优化方式,对于 hooks 为主流的函数式编程,react 也提供了优化方式 memo 方法,本小节我们来了解下它的用...
开源不易,感谢你的支持,❤ star me if you like concent ^_^
hel-micro,模块联邦sdk化,免构建、热更新、工具链无关的微模块方案 ,欢迎关注与了解
本文主题围绕concent的setup和react的五把钩子来展开,既然提到了setup就离不开composition api这个关键词,准确的说setup是由...
ReactsetState的执行是异步还是同步官方文档是这么说的setState()doesnotalwaysimmediatelyupdatethecomponent.Itmaybatchordefertheupdateuntillater.Thismakesreadingthis.staterightaftercallingsetState()apotentialpitfall.Instead,usecom