当前位置: 首页 > news >正文

ReactNativeweexDeviceOne对比

  React Native出来有一段时间了,国内的weex和deviceone是近期发布的,我可以说从2011年就开始关注快速开发的跨平台平台技术了,接触过phoneGap、数字天堂、appcan等早期的移动中间件技术,也跟朋友也讨论过这类的轻量级框架。这些年通过Html5技术或通过Hybrid技术实现跨平台的道路,基本已经快走到头了。尝试跨平台App的开发者们都快碰的头破血流了,大家都在期盼新的更成熟的跨平台开发技术能够早日出来。研究React Natvie的时候,基本大部分时间都在看一些类似的源码,也做了一些分析,最近也对weex和DeviceOne做了一些功课,在这里面做一下自己理解的对比,与大家一起交流,勿喷。
  首先,基本可以肯定的是,大家都把中心转移到原生的效果上,所以,基本三个平台在思想上没有太大的差别。
  1. 首先Reac Native是Facebook产品,而deviceone和weex都是国内公司开发。
  2. React Native 和deviceone 的ios版本使用的javascript引擎使用的都是JSCore,weex和deviceone的android版本使用的是V8.V8的运行性能还是很优秀的,我个人也非常喜欢V8。
  3. React Native 使用的是数据绑定、组件化、前端框架,weex是组件化、数据绑定、前端框架,deviceone是组件化、数据绑定和运行时引擎技术。
  4. 平台要求:
    Android: React Native(API16)、weex(API14)、deviceone(API4)
    ios:React Native、weex、deviceone基本都是ios7.0以上
    windows:React Native需扩展、weex不支持、deviceone已支持。
  我们可以看下接下里的环境配置:
  React Native 需要安装Android,iOS开发环境,很多依赖,相对复杂。
  Weex需要安装Android,iOS开发环境,安装cli,相对简单。
  Deviceone不需要安装Android,iOS开发环境,只需安装deviceone的IDE,简单。
  开发:
  基本三个平台都是JS来开发
  React Native倾向于web方式,需了解android、ios的sdk来写,学习成本和技术要求相对较高。

  Weex也是倾向于web方式,需了解原生sdk来写,学习成本和技术要求相对React Native已经有了很大改进。
  Deviceone更倾向于面向对象,无需了解原生sdk,DeviceOne基本已经实现了一次开发多平台发布的能力。
  调试:
  React Native 可以在chrome查看,不支持节点调试,支持真机调试。
  Weex可以在chrome查看,支持节点调试查看,支持真机调试。
  Deviceone支持真机进行调试,可以实时查看错误信息。
  性能:
  React Native重心比较多,目前性能关注不多。
  Weex公司内部的项目里使用,也一直关注性能。
  Deviceone过去一年里一直在一些真实项目中完善性能。
  如何实现的功能实现,listview的实现:
  React Native用的scrollview来实现,有一些性能问题存在。
  Weex用的recyclerview来实现,性能稍微好一些。
  Deviceone基于原生listview类封装,性能与纯原生系统基本一致。
  案例:
  React Native比较早,国外案例多一些。
  Weex目前刚刚,不是很成熟,案例只有示例类的东西。
  Deviceone成立也比较晚,案例也有一些,基本都是近一年内的案例。
  社区:
  React Native较早,社区人比较多,相对成熟。
  Weex较晚,以公司自己人居多,成熟需一段时间。
  Deviceone较晚,社区人相对少一些,内容相对成熟。

  最后,其实我觉得相对于大家来做选择的时候,如果想要实现快速入门和开发,此时无论选择React Native、Weex还是DeviceOne哪个平台来做都是有道理的,未来还是要看各自的技术发展和服务支撑能力。原生的趋势是大家一致认可的方向,我认为目前我们基本已经不考虑以h5为核心的移动技术了,Web时代的思想是不能适应于移动互联时代的整体需求的。以上只是我的个人见解,谢谢大家。

相关文章:

  • jquery去重
  • 码农看天下
  • nfs/samba相关
  • 定时(隔一段时间)提交ajax更新未读消息
  • 【案例】主从替换之后的复制风暴
  • redis密码管理
  • 认识CoreData-使用进阶
  • CentOS系统误删除文件怎么恢复
  • 各种有用的链接
  • 分享磨砺营马剑威老师讲解-okhttp的优点
  • 逃离烤鸭味的雾霾北京,我们还能去哪里?
  • [nginx文档翻译系列] 控制nginx
  • awakeFromNib相关知识详解
  • Mesos源码分析(15): Test Executor的运行
  • linux软连接硬链接操作与详解
  • [译]CSS 居中(Center)方法大合集
  • 「前端早读君006」移动开发必备:那些玩转H5的小技巧
  • Android优雅地处理按钮重复点击
  • CentOS7 安装JDK
  • css布局,左右固定中间自适应实现
  • HomeBrew常规使用教程
  • JavaScript 事件——“事件类型”中“HTML5事件”的注意要点
  • leetcode46 Permutation 排列组合
  • PermissionScope Swift4 兼容问题
  • 官方解决所有 npm 全局安装权限问题
  • 猫头鹰的深夜翻译:JDK9 NotNullOrElse方法
  • 前端每日实战:70# 视频演示如何用纯 CSS 创作一只徘徊的果冻怪兽
  • 提醒我喝水chrome插件开发指南
  • %check_box% in rails :coditions={:has_many , :through}
  • (13):Silverlight 2 数据与通信之WebRequest
  • (3)(3.5) 遥测无线电区域条例
  • (Matlab)遗传算法优化的BP神经网络实现回归预测
  • (zt)基于Facebook和Flash平台的应用架构解析
  • (顶刊)一个基于分类代理模型的超多目标优化算法
  • (动手学习深度学习)第13章 计算机视觉---图像增广与微调
  • (分享)一个图片添加水印的小demo的页面,可自定义样式
  • (附源码)计算机毕业设计ssm基于Internet快递柜管理系统
  • (附源码)计算机毕业设计SSM智能化管理的仓库管理
  • (机器学习-深度学习快速入门)第三章机器学习-第二节:机器学习模型之线性回归
  • (六)c52学习之旅-独立按键
  • (免费领源码)python#django#mysql校园校园宿舍管理系统84831-计算机毕业设计项目选题推荐
  • (四) 虚拟摄像头vivi体验
  • (五)MySQL的备份及恢复
  • (转)人的集合论——移山之道
  • (转)微软牛津计划介绍——屌爆了的自然数据处理解决方案(人脸/语音识别,计算机视觉与语言理解)...
  • **Java有哪些悲观锁的实现_乐观锁、悲观锁、Redis分布式锁和Zookeeper分布式锁的实现以及流程原理...
  • .360、.halo勒索病毒的最新威胁:如何恢复您的数据?
  • .net core使用RPC方式进行高效的HTTP服务访问
  • .Net程序猿乐Android发展---(10)框架布局FrameLayout
  • /var/spool/postfix/maildrop 下有大量文件
  • @property @synthesize @dynamic 及相关属性作用探究
  • [ vulhub漏洞复现篇 ] GhostScript 沙箱绕过(任意命令执行)漏洞CVE-2019-6116
  • []Telit UC864E 拨号上网
  • [2009][note]构成理想导体超材料的有源THz欺骗表面等离子激元开关——
  • [C puzzle book] types