React Native入门笔记

React Native

概述

五大方面内容:

  • 简介
  • 搭建开发环境
  • 基础语法
  • 架构原理
  • 项目实践

1. 简介

FaceBook 2015 IOS Android reactnative.dev/

移动App的开发模式: 原生开发->原生App->Android、iOS、Windows(X) 混合开发->混合App->Reactive Native(FaceBook)、Weex(Alibaba)、Flutter(Google) H5开发->Web App->HTML、CSS、JavaScript 引擎 JSCore、V8、Flutter engine

RN的优势

  • 开发体验好
  • 开发成本低
  • 学习成本低

RN和客户端的关系

RN-->Bridge-->Andriod(Kotlin | Java) |----->IOS(Swift | Objective-C)

RN的劣势

  • 不成熟
  • 性能差
  • 兼容性差

搭建开发环境概述

    1. 基础环境
    1. 搭建安卓环境
    1. 搭建iOS环境
    1. 初始化项目
  1. 基础环境搭建 安装Node.js->安装Yarn->安装RN脚手架(npm install -g react-native-cli)

!windows下只能搭建Android开发环境;但是Mac下既能搭建Android开发环境,也能搭建iOS开发环境

搭建环境需要科学上网

搭建安卓开发环境

    1. 安装JDK
    1. 安装Android Studio
    1. 安装Android SDK
    1. 配置环境变量
  1. 安装SDK:必须是1.8版本的,需要登陆,然后一直下一步即可,使用java -version验证
  2. 安装Android Studio:下载、安装、启动Android Studio,然后创建项目

!Android Studio会自动安装最新版本的SDK,但是RN需要特定版本的SDK,这就是为什么需要单独下载SDK的原因了。 在Tools下找到SDK Manager,然后按照下面的顺序进行:

初始化项目

  1. 创建项目 react-native init myproject && cd myproject && yarn android
  2. 安装vscode插件 ES7 React/Redux/GraphQL/React-Native snippets 使用快捷命令,例如:rnc rnf
  3. 调试工具: 模拟器会随着Android Studio和Xcode一起安装,启动应用,模拟器也会一起启动-在模拟器中点击一下,然后按下ctrl+m选择debug开始调试
  4. 真机调试:打开USB调试模式-通过USB将电脑和手机连接起来-启动应用,在手机上安装应用

推荐的开发环境

  • win10
  • vs code
  • rn@0.63.3
  • react@16.13.1

基础语法 - style

    1. 掌握React:JSX 组件 生命周期 Hook API Redux 常用安装包
    1. Style Sheet
    1. Flexbox
    1. 组件和API
    1. 路由与导航

RN中的样式与CSS中是不同的:没有继承性(只有Text组件有继承性)、样式名采用小驼峰、所有尺寸都没有单位、有些特殊的样式名称在web开发的时候是没有的(marginHorizontal marginVertical)

样式声明的两种方式:对象或者数组对象(如果是数组形式的,后面的可以覆盖前面的)

样式的使用方式:

js 复制代码
import { StyleSheet } form 'react-native';
const styles = StyleSheet.create({
    foo: fooStyleObj,
    bar: barStyleObj,
});

// 使用
style = {[styles.foo, styles.bar]}

基础语法 - FlexBox

    1. 基本概念:容器、项目、主轴(默认为竖直方向)、交叉轴
    1. 常见属性:flexDirection、justifyContnent、alignItems、flex
    1. 获取屏幕尺寸:import {Dimensions} from 'react-native'; const windowSize = Dimensions.get('window'); const windowWidth = windowSize.width;

基础语法 - 组件和API

    1. 简介
    1. 核心组件:本质上是对原生组件的封装,是来自react-native库的组件;例如Image组件实际上是对Android中的ImageView或者iOS中的UIImageView组件的封装;View或者Text组件也是如此。核心组件可以分成以下几类:基础组件、交互控件、列表视图、iOS或者Android独有组件、其他组件。具体来说核心组件有:View Text Alert Button Switch StatusBar ActivityIndicator Image TextInput Touchable ScrollView SectionList FlatList Animated(组件必须经过特殊处理才能够有动画)
    1. 第三方组件
    1. 自定义组件

Image组件

  • 作用: 加载图片
  • 加载方式:本地路径、网络路径、Base64格式

Touchable组件

  • TouchableHighlight:触碰后高亮显示
  • TouchableOpacity:触碰之后透明度降低
  • TouchableWithoutFeedback:触碰之后没有响应

SafeAreaView组件

用来解决布局中的内容跑到刘海屏下面的问题的组件。

可以直接使用动画的组件

  • Animated.View
  • Animated.Text
  • Animated.ScrollView
  • Animated.Image

创建动画的步骤:

  1. Animated.Value() 初始化单个值
  2. Animated.ValueXY() 初始化向量值
  3. 将初始值绑定到动画组件上去,例如:opacity translate
  4. 逐帧修改初始值:
  • Animated.decay
  • Animated.spring
  • Animated.timing

第三方组件

  • 指的是需要单独通过第三方库安装的组件
  • 使用步骤:安装-配置-使用
  • 常见的第三方组件:WebView Picker Swiper AsyncStorage Geolocation Camera

WebView

Picker

Swiper

AsyncStorage

  • 安装:yarn add @react-native-async-storage/async-storage
  • 配置:github.com/react-nativ...
  • 使用:用来做增删改查用的;一般会对其进行封装并提供set\delete\update\get方法

Geolocation

  • 安装:yarn add @react-native-community/geolocation
  • 配置:github.com/react-nativ...
  • 使用:通过手机获取经纬度信息

Camera

Image-Picker

  • 安装:yarn add react-native-image-picker
  • 配置:github.com/react-nativ...
  • 使用:拍照、扫码、人脸识别、相册

自定义组件

  • 指的就是开发自己封装的可复用的组件

路由和导航

    1. 简介
    1. 基础组件
    1. Stack导航
    1. BottomTab导航
    1. Drawer导航
    1. MaterialTopTab导航

不同于web开发中使用的是React-Router实现路由导航,在RN中是通过React-Navigation进行导航的

5.x reactnavigation.org/

路由的使用:

js 复制代码
import 'react-native-gesture-handler';
import {NavigationContainer} from '@react-navigation/native';

export const App = () => {
    return (
        <NavigationContainer>...</NavigationContainer>
    )
}

Stack导航

  • RN中是没有web端的history对象的,在使用路由之前需要将组件先声明在Stack中:
  • yarn add @react-navigation/stack

使用举例:

js 复制代码
import {NavigationContainer} from '@react-navigation/native';
import { createStackNavigator } from '@react-navigation/stack'
const Stack = createStackNavigator(); 

const HomeScreen = ({}) => {
    return (
        <Button onPress={()=>void navigation.navigate('Details')} title="跳转到详情页">
    )
}

export const App = () => {
    return (
        <NavigationContainer>
            <Stack.Navigator initialRouteName="Details">
                <Stack.Screen name="Home" component={HomeScreen}>
            </Stack.Navigator>
        </NavigationContainer>
    )
}

可以看出来,重要的是:Stack.Navigator Stack.Screen和navigation.navigate.

Navigator属性:

  • initialRouteName
  • headerMode: float screen none
  • screenOptions

Screen属性:

  • options
    • title
    • headerTitleStyle
    • headerStyle
    • headerLeft
    • headerRight
    • headerTinyColor

详细举例如下所示:

未完待续...

相关推荐
screct_demo3 小时前
詳細講一下在RN(ReactNative)中,6個比較常用的組件以及詳細的用法
javascript·react native·react.js
JJIAYin6 天前
RN|系统组件之触摸组件及区别 📝
android·前端·react native
尘云逸6 天前
react native学习【6.1】——列表视图
android·学习·react native
JJIAYin12 天前
RN | class 组件和函数式组件
android·前端·react native
SimonLiu00915 天前
React Native 项目 Error: EMFILE: too many open files, watch
javascript·react native·react.js
HelloZheQ15 天前
从零开始:构建一个简单的聊天应用使用 WebSocket 和 React Native
websocket·网络协议·react native
low神15 天前
在macOS上安装Flutter和环境配置
前端·flutter·react native·macos·前端框架
low神18 天前
Flutter面试题、Dart面试题
前端·javascript·flutter·react native·dart·前端面试题
low神21 天前
Flutter入门,Flutter基础知识总结。
前端·javascript·flutter·react native·uni-app·dart
番茄炒蛋君23 天前
关于React-Native使用intent模式实现pda的一些思路
react native