Hello, React Native

BUILD MOBILE APPS WITH REACT

DMoon

中央資工所

創科資訊工程師

CTJS 2016 講者

React Native Taiwan 社群發起人

前端及 React 愛好者,喜好參與社群交流
近期接觸 React Native 後,開始嘗試跨平台手機應用開發
喜歡前端經常迸出令人驚艷的潮潮東西,還有豐富活躍的社群文化

Blog, Github
dmoon.t@gmail.com

React Native

Released in Sep, 2015 (Android)

然後

一覺醒來

我就會寫 App 了

React

Learn Once, Write Anywhere.

class Welcome extends Component {
  render() {
    return (
      <View>
        <Text>
          Welcome
        </Text>
      </View>
    );
  }
}
class Welcome extends Component {
  render() {
    return (
      <div>
        <span>
          Welcome!
        </span>
      </div>
    );
  }
}

Web

React Native

[問卦] JavaScript 要統治世界了?

JavaScript 能做什麼

  • Web 前端
  • 後端 ( Node.js )
  • Hybrid App ( PhoneGap, Ionic )
  • Desktop App ( Electron )
  • Native Mobile App ( React Native )

誰在使用 React Native

經典範例

React Native 背後原理

React.js 的設計

  • createElement 返回的不是某個實體 DOM 對象,而只是一個數組
  • 透過 lib 將數組轉換成 DOM
  • 底層的渲染核心是可以更換的

React.js

Visual DOM

Web

Component

DOM manipulation by ReactJS

Visual DOM

Native

Object

React Native

ReactJS

Web

Component

?

iOS

Android

Windows

Advantages

&

Disadvantages

Features & Advantages

  • Web 前端開發者易於入門
  • Cross-Platform
  • 模組化及重用性 ( Facebook 團隊程式碼重用率 85% )
  • 開發速度比傳統原生開發更快
  • 相較 Hybrid 效能更高
  • UX 相較 Hybrid 體驗佳
  • Developer Experience (Hot Reloading)
  • 利用動態更新 JavaScript,即時更新 App,快速迭代
  • 自製 Native 元件與 JavaScript 接口,使用 React 調用

Disadvantages

  • 依賴 React Native 提供的元件和功能接口
  • 在開發上仍需要對於原生平台有所瞭解
  • JavaScript 和 Objective-C 之間需要切換,所以性能還是不及原生
  • 尚不穩定,每兩週 Release 一次新版本
  • 升不升級兩難

結論

Z   >   B

環境安裝

  1. Node.js
  2. NPM
  3. react-native-cli
  4. watchman
  5. 原生平台環境
  6. 裝置模擬器

 相比當初學習 React Web 環境

ES6

Webpack

Babel

hot-reload

NPM

live-reload

gulp

browserify

bower

First RN-App

Init Project

$ react-native init FirstRNApp
$ npm install react-native-cli -g

1. Run Simulator (genymotion)

2. Build & Install App on Simulator

$ react-native run-android

 Run Packager Server

$ npm start

You have arrived.

編輯 index.android.js 開始開發

Devtools

 Develope Menu

  1. 按下工具列 menu 按鍵
  2. 快捷鍵 cmd + m (genymotion)
  3. 搖晃裝置 (實體機器)

Red box

Reload

快捷鍵:連按兩下R

從 packager server 拿新的 JS 重新渲染

Live Reload

偵測檔案更動自動 Reload

Hot Reloading

保留狀態更新

Debug JS Remotely

Debug in Chrome

Basic Components

View

創建 UI 最基本的組件,類似 div

Container ,支援 Flexbox 佈局

ScrollView

Text

TextInput

支援屬性

練習: 使用 Component

加入一個 TextInput Component 的名稱欄位

輸入後讓畫面顯示 Hello, XXX

TouchableOpacity

支援屬性

練習:BMI 計算

用兩個 TextInput 分別讓使用者輸入身高, 體重
輸入完成後按按鈕進行計算,用 Text 顯示 BMI 值

Image

支援屬性

雷 1

必須要給寬高

雷 2

練習: pokedex 查詢

一個 TextInput 讓使用者輸入 pokemon index (001~151)

輸入完後點按鈕顯示該神奇寶貝圖片

神奇寶貝圖片url:https://pokeadvisor.com/img/mon/123.png

Style

StyleSheet.create

const styles = StyleSheet.create({
  container: {
    flex: 1,
    justifyContent: 'center',
    alignItems: 'center',
    backgroundColor: '#F5FCFF',
  },
});

與 CSS 相似率高達 87%!

駝峰式的 CSS 屬性名稱

使用樣式

 <View style={styles.container} />

使用多個樣式

 <View style={[styles.container, style.style2]} />

與 Object.assign 相同,若有衝突,右邊優先

增加樣式條件

<View style={[
    styles.base, 
    this.state.active && styles.active
]} />

練習: 樣式套用

  1. render 一個 TouchableOpacity component
  2. 使用 StyleSheet.create 編寫兩個 style ( button1 及 button2),分別設定不同的顏色
  3. 透過按鈕 onPress 的事件觸發時,切換 button 套用的 style

CSS-Layout

Flexbox

FlexDirection

排版方向,預設是 column

row

column

Flex

flexDirection 方向排版比例
<View style={styles.container}>
    <View style={{
        flex: 2,
        backgroundColor: 'lightblue'
    }}>
        <Text>View1</Text>
    </View>
    
    <View style={{
        flex: 1,
        backgroundColor: 'lightgreen'
    }} >
        <Text>View2</Text>
    </View>
</View>

練習: Flexbox 排版

2

1

2

1

1

justifyContent & alignItems

說明 value
justifyContent flexDirection方向的子元素排版 flex-start, center, flex-end, space-around, space-between
alignItems 垂直 flexDirection 方向的子元素排版 flex-start, center, flex-end, stretch

使用第三方套件

1. 安裝 package

2. 若套件有使用到 RN lib 沒有的原生元件,才需要使用

$ rnpm link

# 若沒有安裝過 rnpm ,請先安裝
$ npm install rnpm -g
$ npm install packageName

套件哪裡找?

練習: 使用套件

  1. npm 安裝 React Native App Intro
  2. npm 安裝 React Native Vector Icons
    rnpm link 

Fetch

  const response = await fetch(searchApi, {
    method: 'POST',
    headers: {
      Accept: 'application/json',
      'Content-Type': 'application/json',
    },
    body: JSON.stringify(data),
  });

練習:用 Fetch 發 request

給一個 TextInput 輸入當作 limit 值,輸入完成後按完成按鈕進行發 request 查詢 limit 數內的 pokemon 資料,用 ScrollView 印出所有神奇寶貝名稱及圖片

api: http://pokeapi.co/api/v2/pokemon/?limit=30&offset=0

React Native Workshop (android)

By dmoon

React Native Workshop (android)

  • 2,312