掌握聚合最新动态了解行业最新趋势
API接口,开发服务,免费咨询服务

为什么应该开始使用 React Native 了


在讨论技术方案之前,我们先达成一个共识,如果你的 App 是开发给用户使用的,那么用户并不关心你用的是什么技术方案。因此技术选型,应当是平衡用户体验和开发效率,在这两者之间,应当是满足了用户体验后,再去谈开发效率。

不幸的是,在移动端用户对体验的要求是很高的,而且越来越高。之前我也说,每个 Android 开发者都应该有一个 iPhone,这样才能知道 App 的体验做到什么地步才算及格。这或许会让一些玻璃心的人感到很难受,但我认识的高水平的 Android 开发者,无一例外日常都是在使用 iPhone 或至少有 iPhone 手机。

在过去的半年里,我尝试了三个跨平台的开发工具,Fuse,Qt,以及 React Native. 每个工具都有着巨大的潜力和进步,最终的结论是,Qt 适合开发桌面跨平台程序,React Native 适合用来做 App 开发的补充方案,我们先来谈一谈这三个工具。

Fuse 的尴尬


Fuse 希望既可以是原型工具,又可以由开发者进行生产使用,但这个定位是比较尴尬的,就好像瑞士军刀不能用来剁排骨,大砍刀不能用来做手术一样。

作为原型工具,他需要编译,不能像 Framer.js 那样直接通过网页传递,也不像他那样只用 CoffeeScript 就可以完成整个原型的设计,它太重。

作为开发工具,他的稳定性和性能会出现一些很难解决和控制的边缘 case,使得你不得不自己去封装原生组件,而封装原生组件同样会面对某些 API 不能调用,性能出现问题的边缘 case. 最终殚精竭虑,发现自己浪费了时间。

Qt 在移动端水土不服


Qt 几乎是最优秀的跨平台开发方案,有着数不清的成功案例,我能马上想到的是 Adobe,WPS 和 KDE。Qt 有非常优秀的 GUI 开发方案 QML,也可以用 JavaScript 来写逻辑层,但在移动端,有个问题是他很难解决的。

PC 上的交互是相对单一的,鼠标单击,键盘输入,Qt 提供一套通用型组件就可以够用,但在移动端上,这个问题变得复杂了,手机越来越依赖硬件的创新来实现多样性,很多你日常使用的交互 Feature 都深度结合到了原生控件上,长按复制,3D Touch 这些交互,使用原生控件都开箱既得,因此 QML 和原生控件的差异会越来越大,都需要 Qt 团队或者开发者 Case by case 的去做适配,体验上和原生有一点不一样,就会被用户察觉,这使得 Qt 在 PC 时代的哲学面临了挑战,而 Qt 团队如果没有足够的精力跟进,也会让你备受摧残。

React Native 到来


严格来讲,React Native 不应该被当作一种跨平台解决方案来对待,React Native 给了你一种新的方式去开发 App,React Native 是一种生活方式。

React Native 想对了一件事,就是 UI 开发不应该跨平台,但逻辑层是可以跨平台的。而实际上,React Native 提供给你的,就是一套先进的逻辑层开发框架 + 一套灵活的 UI 开发框架。

React Native 如何处理 UI?


用 React Native 来写 UI 是一件快乐的事情,React Native 没有任何所谓的自己的控件,在 iOS 上,React Native 的每个控件都是调用的原生 API 来做的。

例如:

<View> <Text> Hello World </Text> </View> 

那么就等于 iOS 上的 UIView 添加了一个 UILabel。你不会损失任何 API,但 React Native 却给你提供了更多的糖果使得你可以像 CSS 一样灵活的布局,渲染样式。

除此之外,当你修改 UI 的时候,React Native 支持 Live Reload,你不需要重新编译你的代码,你只需要 Save 一下 JavaScript 文件,界面就会实时更新,这简直节省了无数时间可以用来刷微博。

React Native 的逻辑层?


React 的逻辑层,是一个纯粹的 JavaScript ES6,JavaScript 虽然被骂了很久,但是他也在进化,相信假以时日,ES7 ES8 到来,这也会是一个非常优秀的语言。

其实在学习 React Native 之前,强烈建议先去学习 React,写写网页,先了解 React 是怎么运作的,以及 Redux 这个东西。相较于传统的 MVC 框架来说,React 这套理念会让你的效率倍增。

更何况,你还有 lodash 这种神器。

那么 React Native 到底怎么开始用?


我并不建议你直接用 React Native 重写你的 App,像 Swift 一样,你可以先用 React Native 来实现一部分页面。

或许你用 React Native 写完 App 的登陆页面之后,你就会发现 React Native 的真正益处就在于,让那些体力活的 UI 构建变的越快而充满乐趣。

原文来自:Kevin

声明:所有来源为“聚合数据”的内容信息,未经本网许可,不得转载!如对内容有异议或投诉,请与我们联系。邮箱:marketing@think-land.com

  • 个人/企业涉诉查询

    通过企业关键词查询企业涉讼详情,如裁判文书、开庭公告、执行公告、失信公告、案件流程等等。

    通过企业关键词查询企业涉讼详情,如裁判文书、开庭公告、执行公告、失信公告、案件流程等等。

  • IP反查域名

    IP反查域名是通过IP查询相关联的域名信息的功能,它提供IP地址历史上绑定过的域名信息。

    IP反查域名是通过IP查询相关联的域名信息的功能,它提供IP地址历史上绑定过的域名信息。

  • 人脸卫士

    结合权威身份认证的精准人脸风险查询服务,提升人脸应用及身份认证生态的安全性。人脸风险情报库,覆盖范围广、准确性高,数据权威可靠。

    结合权威身份认证的精准人脸风险查询服务,提升人脸应用及身份认证生态的安全性。人脸风险情报库,覆盖范围广、准确性高,数据权威可靠。

  • 全国城市空气质量

    全国城市和站点空气质量查询,污染物浓度及空气质量分指数、空气质量指数、首要污染物及空气质量级别、健康指引及建议采取的措施等。

    全国城市和站点空气质量查询,污染物浓度及空气质量分指数、空气质量指数、首要污染物及空气质量级别、健康指引及建议采取的措施等。

  • 手机号防骚扰黑名单

    输入手机号和拦截等级,查看是否是风险号码

    输入手机号和拦截等级,查看是否是风险号码

0512-88869195
数 据 驱 动 未 来
Data Drives The Future