跳到主要内容
版本:0.80

React 基础

React Native 运行在 React 之上,这是一个用于使用 JavaScript 构建用户界面的流行开源库。为了充分利用 React Native,理解 React 本身会很有帮助。本节可以帮助你入门,也可以作为复习课程。

我们将涵盖 React 背后的核心概念:

  • 组件
  • JSX
  • props
  • state

如果你想深入挖掘,我们鼓励你查看 React 官方文档

你的第一个组件

这篇 React 介绍的其余部分将以猫为例:友好、亲切的生物,它们需要名字和一个工作的咖啡馆。这是你的第一个 Cat 组件:

做法如下:要定义你的 Cat 组件,首先使用 JavaScript 的 import 导入 React 和 React Native 的 Text 核心组件:

tsx
import React from 'react';
import {Text} from 'react-native';

你的组件起初是一个函数:

tsx
const Cat = () => {};

你可以将组件视为蓝图。函数组件返回的任何内容都会作为 React 元素 渲染。React 元素让你描述你想在屏幕上看到的内容。

此处 Cat 组件将渲染一个 <Text> 元素:

tsx
const Cat = () => {
return <Text>Hello, I am your cat!</Text>;
};

你可以使用 JavaScript 的 export default 导出你的函数组件,以便在整个应用中使用,如下所示:

tsx
const Cat = () => {
return <Text>Hello, I am your cat!</Text>;
};

export default Cat;

这是导出组件的多种方法之一。这种导出方式适用于 Snack Player。但是,根据你的应用文件结构,你可能需要使用不同的约定。这份 关于 JavaScript 导入和导出的便捷速查表 可能会有所帮助。

现在仔细看看那个 return 语句。<Text>Hello, I am your cat!</Text> 使用了一种让编写元素变得方便的 JavaScript 语法:JSX。

JSX

React 和 React Native 使用 JSX,这是一种允许你在 JavaScript 内部编写元素的语法,如下所示:<Text>Hello, I am your cat!</Text>。React 文档有一份 关于 JSX 的综合指南,你可以参考它以了解更多。因为 JSX 是 JavaScript,你可以在其中使用变量。这里你为猫声明了一个名字 name,并使用花括号将其嵌入到 <Text> 中。

任何 JavaScript 表达式都可以在花括号之间工作,包括函数调用,如 {getFullName("Rum", "Tum", "Tugger")}

你可以将花括号视为创建一个通往 JSX 中 JS 功能的门户!

因为 JSX 包含在 React 库中,如果你的文件顶部没有 import React from 'react',它将无法工作!

自定义组件

你已经见过 React Native 的核心组件。React 允许你将这些组件相互嵌套以创建新组件。这些可嵌套、可重用的组件是 React 范式的核心。

例如,你可以在下面的 View 中嵌套 TextTextInput,React Native 会将它们一起渲染:

开发者注

如果你熟悉 Web 开发,<View><Text> 可能会让你想起 HTML!你可以将它们视为应用开发中的 <div><p> 标签。

你可以通过使用 <Cat> 多次渲染此组件,并在多个地方渲染,而无需重复代码:

任何渲染其他组件的组件都是 父组件。此处,Cafe 是父组件,每个 Cat 都是 子组件

你可以在咖啡馆里放任意数量的猫。每个 <Cat> 都会渲染一个独特的元素——你可以使用 props 对其进行定制。

Props

Props 是"properties"的缩写。Props 允许你定制 React 组件。例如,这里你传递每个 <Cat> 一个不同的 nameCat 渲染:

大多数 React Native 的核心组件也可以用 props 定制。例如,当使用 Image 时,你传递给它一个名为 source 的 prop 来定义它显示什么图像:

Image许多不同的 props,包括 style,它接受一个设计与布局相关的属性 - 值对的 JS 对象。

注意围绕 style 宽度和高度的双花括号 {{ }}。在 JSX 中,JavaScript 值使用 {} 引用。如果你传递的不是字符串作为 props,比如数组或数字,这很方便:<Cat food={["fish", "kibble"]} age={2} />。但是,JS 对象 用花括号表示:{width: 200, height: 200}。因此,要在 JSX 中传递 JS 对象,你必须将对象包裹在 另一对 花括号中:{{width: 200, height: 200}}

你可以用 props 和核心组件 TextImageView 构建很多东西!但要构建交互式的東西,你需要 state。

State

虽然你可以将 props 视为用于配置组件渲染方式的参数,但 state 就像组件的个人数据存储。State 对于处理随时间变化的数据或来自用户交互的数据很有用。State 赋予你的组件记忆!

作为一般规则,使用 props 在组件渲染时对其进行配置。使用 state 跟踪你期望随时间变化的任何组件数据。

以下示例发生在一家猫咖啡馆,两只饥饿的猫等待喂食。它们的饥饿感(我们期望随时间变化,与它们的名字不同)存储为 state。要喂猫,请按它们的按钮——这将更新它们的 state。

你可以通过调用 React 的 useState Hook 向组件添加 state。Hook 是一种让你“钩入”React 功能的函数。例如,useState 是一个允许你向函数组件添加 state 的 Hook。你可以在 React 文档中了解更多关于其他类型的 Hook。

首先,你需要像这样从 React 导入 useState

tsx
import React, {useState} from 'react';

然后通过在组件函数内调用 useState 来声明组件的 state。在此示例中,useState 创建一个 isHungry state 变量:

tsx
const Cat = (props: CatProps) => {
const [isHungry, setIsHungry] = useState(true);
// ...
};

你可以使用 useState 跟踪任何类型的数据:字符串、数字、布尔值、数组、对象。例如,你可以跟踪猫被抚摸的次数 const [timesPetted, setTimesPetted] = useState(0)

调用 useState 会做两件事:

  • 它创建一个具有初始值的"state 变量"——在此情况下,state 变量是 isHungry,其初始值是 true
  • 它创建一个函数来设置该 state 变量的值——setIsHungry

你使用什么名字并不重要。但将模式思考为 [<getter>, <setter>] = useState(<initialValue>) 会很有帮助。

接下来你添加 Button 核心组件并给它一个 onPress prop:

tsx
<Button
onPress={() => {
setIsHungry(false);
}}
//..
/>

现在,当有人按下按钮时,onPress 将触发,调用 setIsHungry(false)。这将 state 变量 isHungry 设置为 false。当 isHungry 为 false 时,Buttondisabled prop 设置为 true,其 title 也会改变:

tsx
<Button
//..
disabled={!isHungry}
title={isHungry ? 'Give me some food, please!' : 'Thank you!'}
/>

你可能已经注意到,虽然 isHungry 是一个 const,但它似乎可以重新赋值!发生的情况是,当调用像 setIsHungry 这样的 state 设置函数时,其组件将重新渲染。在此情况下,Cat 函数将再次运行——这次,useState 将给我们 isHungry 的下一个值。

最后,将你的猫放入 Cafe 组件中:

tsx
const Cafe = () => {
return (
<>
<Cat name="Munkustrap" />
<Cat name="Spot" />
</>
);
};

看到上面的 <></> 了吗?这些 JSX 片段是 fragments。相邻的 JSX 元素必须包裹在一个封闭标签中。Fragments 让你这样做,而无需嵌套额外的、不必要的包装元素,如 View


现在你已经涵盖了 React 和 React Native 的核心组件,让我们通过查看 处理 <TextInput> 来更深入地探讨一些这些核心组件。