Разработка мобильных приложений на React Native
2016, AnjLab, Николай Жебрун
React
- Facebook, June 2013
- V in MVC
- No assumptions about rest technology stack
React Virtual DOM
- Abstracts from DOM
- Declarative UI, related data, events
- Reacts on state changes using diffs
JSX
UI=func(state)
UI=func(state)
var state = { label: 'Name', value: 'AnjLab' }
var changeHandler = function() {
console.log('On input change')
}
var App = (
<Form>
<FormRow>
<FormLabel text={state.label} />
<FormInput value={state.value}
onChange={changeHandler}/>
</FormRow>
</Form>
);
React DOM
React Canvas
data:image/s3,"s3://crabby-images/9371d/9371ddf394a46b50a983a339cd5eb3609bf0eb79" alt=""
data:image/s3,"s3://crabby-images/cb542/cb542f8272855426e38f374d4f311aefafed569a" alt=""
React Native
-
React Desktop
-
React DOM Server Rendering
-
Testing
data:image/s3,"s3://crabby-images/26ba4/26ba4ee42d7575dc4e358d83b6a333b3261e657f" alt=""
React Components
- Strong hierarchy
- Components are just State Machines
- State
- Props
- Reusable components: Props Validation
data:image/s3,"s3://crabby-images/06c27/06c270218330f2a6fe5deeeabc6af0b126dd0491" alt=""
Flux
data:image/s3,"s3://crabby-images/c1b69/c1b69be52862a516bb6404cb184e5f2d243f1bfd" alt=""
- Unidirectional flow
- No cascading updates
- App state in stores
Redux
Single Store
console.log(store.getState());
Output:
{
form: {
value: 'AnjLab'
}
}
Store state is immutable
var action = {
type: CHANGE_VALUE,
value: 'TechTalks'
}
store.dispatch(action);
store.dispatch(action2);
...
Reducers make changes
function changeFormValue(state: {
value: 'Initial'
}, action) {
switch (action.type) {
case 'CHANGE_VALUE':
return { value: action.value };
default:
return state;
}
}
import { combineReducers, createStore } from 'redux';
let reducer = combineReducers({
form: changeFormValue
});
let store = createStore(reducer);
Redux Middlewares
Async Actions
- Thunk (action creators)
- Promises
- RX Observables
- Sagas
Logging
data:image/s3,"s3://crabby-images/39823/39823f4f549abe083f54caf10474b9940e41dbf5" alt=""
Dev Tools
data:image/s3,"s3://crabby-images/69747/69747ae1d7181f7de66d8b336632ede014b201b7" alt=""
React Native
- Facebook, Jan 2015
- iOS and Android
- Native Modules and Components
data:image/s3,"s3://crabby-images/67cf2/67cf2660820e0f40e614d83c2e4e82e839234480" alt=""
Styles
Flexbox
var styles = StyleSheet.create({
base: {
width: 38,
height: 38,
},
background: {
backgroundColor: '#222222',
},
active: {
borderWidth: 2,
borderColor: '#00ff00',
},
});
<Text style={styles.base} />
<View style={[
styles.base, styles.background
]} />
data:image/s3,"s3://crabby-images/7f232/7f232fb1545d735f197e617d8114cb6c10704d75" alt=""
- margins
- paddings
- absolute position
- dimensions
RN Toolkit
Dev NodeJS Packager
$ npm install
$ react-native run-ios
$ react-native run-android
Inspector & Perf Monitor
data:image/s3,"s3://crabby-images/b18a5/b18a5e82cf27d24969cbe535931750b62b1d8a37" alt=""
data:image/s3,"s3://crabby-images/a3cac/a3cace8e833b3697f4e03580bc29095fc45f8fbc" alt=""
Systrace
React Native Architecture
data:image/s3,"s3://crabby-images/0d2a9/0d2a97e6d9671523b3a0dba7a3177c4bf6c1797c" alt=""
Pros
- Declarative UI
- Flexbox layouting
- Async: 60 FPS
- Universal components
- Hot reload
- Fast development time
- React: learn once write everywhere
- Small release cycles (code push)
- Great ecosystem & community
Cons
- Performance issues
- Universal components