React Native
in
Project
Pain points of UX experiment today
-
Client side UX experiment is slow
- Requires app update even for small changes.
- Cost of release process eats away benefit if app is released too frequently.
-
Expensive to conduct experiment on two platforms
- UX development on Android and iOS is completely different.
- Have to choose one platform at the expense of coverage due to resource constraint.
-
Lack of control after experiment payload is distributed
- Not all users will update app on regular basis.
- Problem introduced in experiment cannot be quickly fixed.
- Cannot pause an active experiment.
React Native
- Cross platform
- Everything in JavaScript
- All about UI
- Not a Webview
- Apply to an existing App
- Productivity
- Open-Source
- Node.js eco-system
Why React Native?
-
Cross platform
-
Expensive to conduct experiment on two platforms
-
-
Productivity
- Modularity, less code
- Hot reloading
-
Flexible deployment mechanism
-
Client side UX experiment is slow Lack of control after experiment payload is distributed
-
-
Backed by Facebook and big dev community
-
Skype is using React Native to build next generation experience with Cortana integrated.
- Opportunity to leverage work from Skype
-
Skype is using React Native to build next generation experience with Cortana integrated.
Architecture
data:image/s3,"s3://crabby-images/808d1/808d1c4dc9a3e6380d5a0a88e4407e39bd542568" alt=""
Engineering Process
- CortanaReactNative Repo is independently clone into CoA / CoI repo.
- Develop independently
-
Packaged into ipa / apk in build time
- CortanaReactNative modules
- Image assets
- JS Bundle
Development
data:image/s3,"s3://crabby-images/5b747/5b7471b21a30b60b13a9cde658906a798ef3a580" alt=""
CodePush
data:image/s3,"s3://crabby-images/3ff8e/3ff8e65ffa5a070ccbd636969cc8ed317c2ac21f" alt=""
data:image/s3,"s3://crabby-images/f7d69/f7d69d6cd86b92521fd4daa386d548cce24d9092" alt=""
data:image/s3,"s3://crabby-images/66593/66593888390b0212e25889202c5bda508ad82620" alt=""
data:image/s3,"s3://crabby-images/5c47b/5c47be85d632846d948ca6cac91ad416be0e28e5" alt=""
React Native in Project
By Vince Liu
React Native in Project
- 461