示例教程:Hello World
React Native 看起来很像 React,只不过其基础组件是原生组件而非 web 组件。要理解 React Native 应用的基本结构,首先需要了解一些基本的 React 的概念,比如 JSX 语法、组件、state
状态以及props
属性。如果你已经了解了 React,那么还需要掌握一些 React Native 特有的知识,比如原生组件的使用。这篇教程可以供任何基础的读者学习,不管你是否有 React 方面的经验。
让我们开始吧!
Hello World
根据历史悠久的“传统”,我们也来写一个“Hello, world!”:
你可以直接在上面的编辑器里改改试试,也可以新建一个项目,然后用上面的代码覆盖你的App.js
文件,然后运行看看。
那这段代码是什么意思呢?
- First of all, we need to import
React
to be able to useJSX
, which will then be transformed to the native components of each platform. - On line 2, we import the
Text
andView
components fromreact-native
Then we find the HelloWorldApp
function, which is a functional component and behaves in the same way as in React for the web. This function returns a View
component with some styles and aText
as its child.
The Text
component allows us to render a text, while the View
component renders a container. This container has several styles applied, let's analyze what each one is doing.
The first style that we find is flex: 1
, the flex
prop will define how your items are going to "fill" over the available space along your main axis. Since we only have one container, it will take all the available space of the parent component. In this case, it is the only component, so it will take all the available screen space.
The following style is justifyContent
: "center". This align children of a container in the center of the container's main axis and finally we have alignItems
: "center", which align children of a container in the center of the container's cross axis.
初看这段代码,可能觉得并不像 JavaScript——没错,这是“未来”的 JavaScript.
首先你需要了解 ES2015 (也叫作 ES6)——这是一套对 JavaScript 的语法改进的官方标准。但是这套标准目前还没有在所有的浏览器上完整实现,所以目前而言 web 开发中还很少使用。React Native 内置了对 ES2015 标准的支持,你可以放心使用而无需担心兼容性问题。上面的示例代码中的import
、from
、class
、extends
、以及() =>
箭头函数等新语法都是 ES2015 中的特性。如果你不熟悉 ES2015 的话,可以看看阮一峰老师的书。
示例中的这一行<View><Text>Hello world!</Text></View>
恐怕很多人看起来也觉得陌生。这叫做 JSX——是一种在 JavaScript 中嵌入 XML 结构的语法。很多传统的应用框架会设计自有的模板语法,让你在结构标记中嵌入代码。React 反其道而行之,设计的 JSX 语法却是让你在代码中嵌入结构标记。初看起来,这种写法很像 web 上的 HTML,只不过使用的并不是 web 上常见的标签如<div>
或是<span>
等,这里我们使用的是 React Native 的组件。上面的示例代码中,使用的是内置的<Text>
组件,它专门用来显示文本,而<View>
就类似 html 中的div
或是span
这样的容器。