React Native VS REACT + WebView
Alexey Kosinskiy
data:image/s3,"s3://crabby-images/49cd4/49cd4ccfec01957e04eff0512b14f873decbad62" alt=""
data:image/s3,"s3://crabby-images/3fbee/3fbee046ddba02287a6234a60df36a4c87d7af6e" alt=""
Alexey Kosinski
Senior Frontend Developer
avkos
avkosinski
avkosinski
data:image/s3,"s3://crabby-images/cf220/cf220808326245cec9139459ce0204df27fa03d6" alt=""
data:image/s3,"s3://crabby-images/31523/315232ca211021aaeea3a6e9b3ea42b7168f1cf5" alt=""
data:image/s3,"s3://crabby-images/8ad2b/8ad2b5fe715acf91af60e1c74c3f33ccea9d21f4" alt=""
What is WebView?
data:image/s3,"s3://crabby-images/de353/de353b74f5f7c376e445a5ae8a85173b0e577eb3" alt=""
data:image/s3,"s3://crabby-images/0dba1/0dba1d53eb62f03be682eb8d7ddfafa869180fe5" alt=""
data:image/s3,"s3://crabby-images/0dba1/0dba1d53eb62f03be682eb8d7ddfafa869180fe5" alt=""
data:image/s3,"s3://crabby-images/0dba1/0dba1d53eb62f03be682eb8d7ddfafa869180fe5" alt=""
data:image/s3,"s3://crabby-images/0dba1/0dba1d53eb62f03be682eb8d7ddfafa869180fe5" alt=""
data:image/s3,"s3://crabby-images/0dba1/0dba1d53eb62f03be682eb8d7ddfafa869180fe5" alt=""
data:image/s3,"s3://crabby-images/0dba1/0dba1d53eb62f03be682eb8d7ddfafa869180fe5" alt=""
IOS
Android
Web
data:image/s3,"s3://crabby-images/0dba1/0dba1d53eb62f03be682eb8d7ddfafa869180fe5" alt=""
data:image/s3,"s3://crabby-images/0dba1/0dba1d53eb62f03be682eb8d7ddfafa869180fe5" alt=""
data:image/s3,"s3://crabby-images/0dba1/0dba1d53eb62f03be682eb8d7ddfafa869180fe5" alt=""
WebView
React
LOADING REACT+WEBVIEW
WEBVIEW
SERVER
JS bundle
REACT
YOUR APP
LOCAL
FILE
STORAGE
LOADING REACT NATIVE
NATIVE CONTROLLER
LOCAL
FILE
STORAGE
JS bundle
REACT NATIVE
YOUR APP
React + WebView
React Native
data:image/s3,"s3://crabby-images/7b702/7b702dc219e135757198e617a4b6ac54bb789358" alt=""
data:image/s3,"s3://crabby-images/8d584/8d584b75048c21c98615127325d1fa56fa832748" alt=""
data:image/s3,"s3://crabby-images/8d584/8d584b75048c21c98615127325d1fa56fa832748" alt=""
data:image/s3,"s3://crabby-images/8d584/8d584b75048c21c98615127325d1fa56fa832748" alt=""
PC
Mobile Browser
IOS
Android
data:image/s3,"s3://crabby-images/8d584/8d584b75048c21c98615127325d1fa56fa832748" alt=""
data:image/s3,"s3://crabby-images/8d584/8d584b75048c21c98615127325d1fa56fa832748" alt=""
IOS
Android
data:image/s3,"s3://crabby-images/8d584/8d584b75048c21c98615127325d1fa56fa832748" alt=""
Windows
Example Simple App Video
React + WebView
React Native
data:image/s3,"s3://crabby-images/bed51/bed51655a54114932c6abf3d0277c20d3644c13e" alt=""
data:image/s3,"s3://crabby-images/bed51/bed51655a54114932c6abf3d0277c20d3644c13e" alt=""
data:image/s3,"s3://crabby-images/bed51/bed51655a54114932c6abf3d0277c20d3644c13e" alt=""
data:image/s3,"s3://crabby-images/80bbb/80bbb2aae175c94c2aa78046dd572fc6bfa5ca29" alt=""
Render Test
let style={ backgroundColor: `rgb(${r},${g},100)`, width: 1, height: 1,
display:'inline-block' };
let style = { backgroundColor: `rgb(${r},${g},100)`, width: 1, height: 1 };
React
React-Native
Styles
for (let r = 0; r < 255; r = r + 10) { green[r] = []; for (let g = 0; g < 255; g++) { cnt++; green[r].push(<div key={`s${r}-${g}`} style={...} />) } red.push(<div key={`v${r}`}>{green[r]}</div> ) }
React cycle
for (let r = 0; r < 255; r = r + 10) { green[r] = []; for (let g = 0; g < 255; g++) { cnt++; green[r].push(<View key={`s${r}-${g}`} style={...} />) } red.push(<View key={`v${r}`}>{green[r]}</View>) }
React Native cycle
data:image/s3,"s3://crabby-images/0dba1/0dba1d53eb62f03be682eb8d7ddfafa869180fe5" alt=""
data:image/s3,"s3://crabby-images/0dba1/0dba1d53eb62f03be682eb8d7ddfafa869180fe5" alt=""
React + WebView
React Native
data:image/s3,"s3://crabby-images/3a14b/3a14baf816fa0a2884a58002258e6a27621bd7cc" alt=""
React Native
React + WebView
render() { let {R, G, B} = this.state; return <View style={{ height: 500, backgroundColor: `rgb(${R},${G},${B})` }}/>; }
render() { let {R, G, B} = this.state; return <div style={{ height: 500, backgroundColor: `rgb(${R},${G},${B})` }}/>; }
Test 2 - One block
React Render
React Native Render
React + WebView
React Native
React Native
React + WebView
data:image/s3,"s3://crabby-images/a487c/a487cb6e864e8cfef29bd17e62419d85cddd8837" alt=""
Animations
data:image/s3,"s3://crabby-images/0d708/0d708fd0575841f336dc2a74b8e08a7c3f31af7a" alt=""
React Animations
Re-Render
data:image/s3,"s3://crabby-images/1a2cb/1a2cb171906ac6534068def2287fa4e5b21706c2" alt=""
data:image/s3,"s3://crabby-images/1ed46/1ed461f5e2eebce4d82f6970189c5fbe6ab42538" alt=""
data:image/s3,"s3://crabby-images/8b7f9/8b7f9a0c6a4227a853eb9e42e062b5fc7ca37049" alt=""
Transitions
Animations
React Animations
Transitions
Animations
data:image/s3,"s3://crabby-images/740de/740de46a5a85793c9c49baee1cfb0a4c45ba75a7" alt=""
data:image/s3,"s3://crabby-images/b66c9/b66c92da9a21a1e7717d525fb8eddf85167f7fd4" alt=""
React Native Animations
JS
Native
Controller
Native
Component
Transitions and Animations Example
React
React Native
<div/>
CSS3
ReactCSSTransitionGroup
<Animated.View/>
Animated
classes + styles
time-functions
Transitions and Animations Example
React + WebView
React
Native
GPU
Draw
Command issue
Swap buffers
16ms
GPU
React + WebView
React Native
data:image/s3,"s3://crabby-images/8d584/8d584b75048c21c98615127325d1fa56fa832748" alt=""
Native API
Custom API
or
Framework
Cordova
Components
Custom API
window.mobileApi.scanQR();
document.mobileApi.pushNotification(data);
React + WebView
React Native
Devices
Render
Animations
Native API
Native
$8 000
$12 000
$38 000 - $70 000
Cost
GPU
HOLY WAR
React-Native VS React+WebView
By Alexey Kosinski
React-Native VS React+WebView
- 3,557