基于ReactNative实现的博客园手机客户端

注:升级版本请移步:http://www.cnblogs.com/mcmurphy/p/5934993.htmlphp

去年九月,facebook发布了react-native,将web端的javaScript和react技术扩展到了IOS和Android的原生应用开发。用一句大白话来讲,就是利用相同的核心代码,就能够搞出androidapp,iosapp,以及后台应用程序。同时,得益于它的热更新能力,软件更新再也不须要用户下载新的安装包,就像传统的web网页同样,服务器有修改,终端可即时接触到最新内容。多端技术统一,热更新,原生的体验,真正拥有了这些,才发现当前广泛的移动端开发有多么蛋疼。就像桌面时代的cs结构程序开发很大程度上已经被bs结构所取代同样,移动端的这一进程,会进行的更快。html

出于学习及实践的目的,此次用react-native构建了一个博客园的手机客户端,由于没有ios的开发环境(穷),因此当前仅仅支持安卓平台(>=android 4.1.6),但适配ios的话,预估至多也就20%的工做量。前端

实现功能

  • 首页 & 排行 & 新闻等列表查看
  • 博文详情 & 新闻详情查看
  • 热门博主查看及博主检索
  • 博主详情及博主博文列表
  • 博文评论 & 新闻评论查看
  • 博主及新闻离线收藏及查看
  • 设置 & 关于
  • CodePush代码热更新

因为博客园官方开放接口所限,而我又不倾向于经过非正规手段实现目的,如下列举一些很重要但并未实现的功能:java

  • 用户登陆
  • 发表评论
  • 博文发表
  • 博文分类别查看
  • 评论消息通知等。

页面截图

this is a picture of gif, may die

this is a picture of gif, may die

home page

detail page

author page

comment page

offline page

search page

下载入口

可扫码直接下载体验:react

search page

或访问如下连接下载:
http://fir.im/togaytherandroid

存在的问题

  • 详情页面HTML解析组件仍然存在一些性能和细节问题,对于一些长博客的渲染会耗费比较长的时间。
  • 博主详情、博文详情等接口会出现偶尔不会返回数据的问题。
  • 接口返回的数据格式为xml,对于前端的解析不够友好。我我的搭建了一个php的中间层。因此客户端请求的接口地址为:123.56.135.166。
  • 当前app引用的图标为本身创做,由于找了好久也没有找到博客园相关的app图标资源。不知道这样会不会有什么问题。
  • 站内连接应用内跳转查看(官方博文详情接口调用须要传入博文id,但不少博文都自定义了连接,这个还须要再斟酌一下)。
  • 一些性能问题。
  • IOS适配的问题,看接下来个人时间安排吧。
  • 其它一些交互及功能完善。

源码地址

https://github.com/togayther/react-native-cnblogs
有任何问题,可在博文下方留言,或提交issue。ios

一点后话

在可预知的将来,构建移动端产品的工具及生产力,必定会伴随着科学技术的发展,变得愈来愈简单和统一。你很难想像时代的进步造福了全人类,但IT从业人员却仍然苦逼的为了兼容各大平台而感受身体被掏空。就像如今不少原生开发人员开始抱怨工做没有前几年那么好找,其实必定程度上,缘于不少公司的技术选型发生了变化,更加倾向于以一种轻便统一的方式构建业务应用,react-native 当前在业内的热度也印证了这一点。做为技术人员,应该时刻关注行业动态,扩展视野,更新本身的技术栈,才能保证本身的竞争力。在这里祝各位园友工做顺利,也祝博客园紧跟移动互联网浪潮,愈来愈好!git

相关文章
相关标签/搜索