Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
カンムでの React Native の 歴史と現在 / React Native in Kanmu
Search
mururu
September 03, 2020
Technology
1
460
カンムでの React Native の 歴史と現在 / React Native in Kanmu
mururu
September 03, 2020
Tweet
Share
More Decks by mururu
See All by mururu
Go で始める将棋 AI
mururu
1
2.7k
カンム と React Native / Kanmu React Native
mururu
0
3.5k
Go製のネットワーククライアントに対する継続的 / Fuzzing for network client in Go
mururu
4
2.6k
Building FIDO2 server in Go
mururu
2
6.7k
「ElixirがリアルタイムWebに強い」 というのは本当か?
mururu
13
6.5k
Erlang: Improve the performance of cryptographic functions by AES-NI
mururu
1
220
Treasure Data Summer Intern 2015 Final Report
mururu
0
3.1k
Elixir 1.0
mururu
3
820
Why Elixir
mururu
9
2k
Other Decks in Technology
See All in Technology
目標と時間軸 〜ベイビーステップでケイパビリティを高めよう〜
kakehashi
PRO
8
830
入門 PEAK Threat Hunting @SECCON
odorusatoshi
0
170
OCI Success Journey OCIの何が評価されてる?疑問に答える事例セミナー(2025年2月実施)
oracle4engineer
PRO
2
170
【詳説】コンテンツ配信 システムの複数機能 基盤への拡張
hatena
0
280
クラウド食堂とは?
hiyanger
0
120
マーケットプレイス版Oracle WebCenter Content For OCI
oracle4engineer
PRO
3
540
Pwned Labsのすゝめ
ken5scal
2
510
技術スタックだけじゃない、業務ドメイン知識のオンボーディングも同じくらいの量が必要な話
niftycorp
PRO
0
120
Autonomous Database Serverless 技術詳細 / adb-s_technical_detail_jp
oracle4engineer
PRO
17
45k
2025/3/1 公共交通オープンデータデイ2025
morohoshi
0
100
LINEギフトにおけるバックエンド開発
lycorptech_jp
PRO
0
380
Охота на косуль у древних
ashapiro
0
120
Featured
See All Featured
Templates, Plugins, & Blocks: Oh My! Creating the theme that thinks of everything
marktimemedia
30
2.2k
Measuring & Analyzing Core Web Vitals
bluesmoon
6
260
JavaScript: Past, Present, and Future - NDC Porto 2020
reverentgeek
47
5.2k
BBQ
matthewcrist
87
9.5k
KATA
mclloyd
29
14k
Done Done
chrislema
182
16k
Why Our Code Smells
bkeepers
PRO
336
57k
Facilitating Awesome Meetings
lara
53
6.2k
Git: the NoSQL Database
bkeepers
PRO
428
65k
Product Roadmaps are Hard
iamctodd
PRO
51
11k
CSS Pre-Processors: Stylus, Less & Sass
bermonpainter
356
29k
Performance Is Good for Brains [We Love Speed 2024]
tammyeverts
7
650
Transcript
カンムでの React Native の 歴史と現在 Kanmu, Inc. 伊藤 友気 【Kanmu
× Nature】React Native Meetup
2 伊藤 友気 Kanmu, Inc. @mururu @murururu ⾃⼰紹介
3 バンドルカードを作ってます
4 歴史 現在の構成 これから 1 2 3 アジェンダ
歴史 1
6 バンドルカードのはじまり • バンドルカードの前にやっていたプロダクトの反省 から⾃分たちでカードを発⾏するべきだと判断 • 当時の開発チーム • 開発者3⼈(内⼀⼈は兼デザイナー) •
3⼈とも Web の開発経験はあったがネイティブ開 発経験はない
7 バンドルカードのはじまり • 2015年12⽉ 開発開始 • 2016年9⽉ iOS版リリース • 2016年12⽉
Android版リリース
8 なぜ React Native だったのか • ネイティブ開発経験のない少数の開発者で、素早く アプリをそれなりのクオリティでリリースしたかっ た
9 課題① Android 版リリース 開発初期は iOS のみでとりあえず実装してリリース し、Android 版もそこまで⼤きな変更は必要ないと⾒ 込んでいた
実際にはアニメーション系などいくつかクラッシュす る部分の発⽣や、iOS しか対応していないライブラリ なども導⼊してしまっていた プラットフォームによる分岐、機能の変更などによ り、なんとかリリースにこぎつける 後にアプリケーションレベルでのプラットフォームご との分岐は解消 →
10 課題② Android 4.4 系対応 もともと Android 4.4 系で原因特定が難しいクラッ シュが発⽣しがちであった
Android の 64bit 対応のため React Native 0.60 への アップデートを試みた所、Android 4.4 系でのクラッ シュが爆増し断念 4.4 系のサポート終了を決定 終了までの間 Multiple APK にして 64bit対応版/⾮対応 版を別ブランチで管理 →
現在の構成 2
12 現在の構成 • React Native, JavaScript, Flow, Redux, Storybook, Firebase
など • ⽇常のほとんどの開発が React の世界のエコシステ ムの範囲ですんでいる • Expo は使っていない • リリースサイクルはおよそ週1
13 ビルド/リリース周り • 基本的にビルド/リリースはfastlaneで完結させ、CI はBitriseにのせている • lint や Jest でのテストなどは社内の別のプロジェク
トと共通で CircleCI 利⽤ • 開発版の社内への配布は DeployGate を利⽤
14 ビルド/リリース周り
15 API 連携 • JSON Hyper-Schema からAPIクライアントの実装を ⾃動⽣成している • バックエンドのAPIサーバーも同じスキーマからリク
エスト/レスポンスの構造体やバリデーション実装を ⾃動⽣成している
16 デバッグ • react-native-debugger • react-devtools や redux-devtools 相当の機能 •
ネットワークのデバッグ • ネイティブのエレメントの検証など • Flipper に移⾏予定
17 Storybook • いわゆるUIコンポーネントカタログ的にはなっておら ず、コンポーネント開発時にコンポーネントのみを確 認するような⽤途で利⽤している • ほぼ全てのコンポーネント/ページをStorybook化して いる •
Storyshots で Snapshot testing を⾏っている
18 • Sentry • 当初よりエラートラッキングに利⽤ • Firebase Crashlytics • クラッシュレポート
• Firebase で記録しているイベント紐付けられる ので便利 エラートラッカー/クラッシュレポート
19 • Analytics • ⾏動ログは Firebase Analytics で収集 • react-navigation
の遷移イベントをフックにペー ジ遷移のトラッキングなども • Remote Config • 任意のタイミングで表⽰を切り替えたい場合 (ex. アドホックな⽂⾔の変更 • A/B テスト Firebase の他の機能
これから 3
21 TypeScript 移⾏ • 現状は Flow + JavaScript • そろそろ
Flow をサポートしないライブラリも出て きているので、⾝動きが取れなくなる前に TypeScript に移⾏したい • 変換ツールもあるが⼀筋縄では⾏かない感じがして いるので、泥臭い作業になりそう
22 デザイン連携の効率化 • 現状、実装とデザインの⼀致してない部分がある • ⼀貫したUIを素早く効率的に提供できるようにした い • Atomic Design
ベースでコンポーネントをデザイ ナーと共に認識を合わせながら整理している
まとめ 4
24 まとめ • Web の開発者ならば基本的に開発にはすぐ⼊れる • ただしハマったときはネイティブの知識がないとや はりしんどい • バンドルカードは都度ハマりながら進んできました
We are hiring!
おわり