关闭

一个完整小巧的Redux全家桶项目

标签: react-nativereduxredux-sagareduxthunkpersist
507人阅读 评论(0) 收藏 举报
分类:

OneArticle: 使用React-Native开发,使用Redux,React-Redux,Redux-Persist,Redux-Saga。

icon

为什么取这个名字呢,我也不想啊,App为OneArticle,但发现数据源的官方应用以前就叫一文,让后我叫一文就不好了。项目地址

一:应用介绍

  1. 我的项目地址Android端演示 – IOS端,模拟器测试过是没有问题,打包出来?没有开发者账号(笑脸+尴尬),但模拟器测试是OK的。流下了贫穷的眼泪
  2. 我的数据来源: OneArticle
  3. 官方正版:观止APP地址:IOS版Android版,产品介绍:不用登录注册,没有复杂的算法,不猜你喜欢。和你一样我们喜欢简单,相信优美文字的力量,并乐于坚持。
  4. 在此声明我什么版也不是,只是使用他们数据做个演示,不得将此应用发布和打包,违规者后果自负。

之前写的纯原生RN项目Mung

二 : 界面演示

iphone.png

android.png

三: 功能介绍

  • 主题换肤 :实现了无缝换肤,这个算是Redux优势,非常简单。
  • 收藏本地化和简单缓存 :每篇收藏的文章都会被保存下来,最近浏览的十篇文章也会被缓存。
  • 分享功能 : 实现了微信和朋友圈的分享。
  • 无缝切换文章:无缝切换文章实现不会数据冲突。

可以下载个官方的对比下功能全部实现了,简单改了下布局,主要是实战Redux。

四: redux-thunk 和 redux-saga

  1. 使用redux他们是必选的,一般都是二选一,redux-thunk redux-saga 两个都可以很好的实现一些复杂情况下redux,本质都是为了解决异步action而生,使redux保持完整性,不至于太过混乱。redux-saga 是一个用于管理 Redux 应用异步操作的中间件。 redux-saga 通过创建 Sagas 将所有的异步操作逻辑收集在一个地方集中处理,可以用来代替 redux-thunk 中间件。而且提供了takeLatest/takeEvery可以对事件的仅关注最近事件、关注每一次、事件限频;reudx-saga更方便测试,等等太多了。

五:要求

  1. 本项目适合已经能熟练使用React-native基本控件。
  2. 这里直接讲项目里redux的一些实战问题,其他自己看。

六:redux-persist

项目中redux-persist主要是为了保持数据而它的使用非常简单,可以先简单的看下官网就可以看懂主要也没几个方法,这里只讲开发时遇到的问题:redux-persist存储是将整个redux都存储的,但开发时会有一些临时数据不需要存储,如本项目的Modal的显示,和请求状态的存储,不可能每次已进入还没请求state的请求状态就为成功吧,这明显是不对的,而且最新的版本V5+也重点优化这方面。
1. 一个是设置的适合设置blacklist黑名单,黑名单里的数据不会保持起来。当然对应的还有白名单whitelist就是仅仅保持名单里的数据,但有个问题开发时每个reducer都是复制单个模块的,而白黑名单只能为一级对象,这样单个reducer里的状态就不能进入名单了。
2. 将要忽略的状态写在一个单独的reducer里,这样在写黑名单是就可以将其写进去进行忽略,但这将不太适合维护,例如有些状态属于styles,有些状态属于splash如果都写一起,将会缺乏reducer的专一性。
3. persistCombineReducers和persistReducer进行单个reducer的添加白黑名单再设置stateReconciler为reconciler(数据合并的意思),将可以操控到单个reducer的单个状态。

七: redux-saga

如果你没有学过redux-saga这篇中文文档应该很适合你redux-saga中文文档,里面把redux-saga所以方法和用法和原理都讲的很好,可以带你熟练使用。这里主要用到redux-saga进行数据请求和取消请求,下面是项目redux-saga使用的一部分。

/*
* 文章显示只有一篇,请求数据时最多也只能有一种
*   1.解释当请求今天文章花费10s,请求特定一天今天文章需要4s当请求今天文章后2s后请求特定一天文章结果是
*       6s后特定一天文章出来了,刷新。10s后今天文章刷新出来了,这结果显然不对吧。
*       正常是2s后取消当前正在请求的所以文章,在进行新的请求这样才对,这就是下面的写法的解释。
*   2. 解释下take加cancel可以编写出takeLatest,fork第一个参数:需是 Generator 函数, 或者返回 Promise 的普通函数
* */
function* watchRequestArticle() {
    let lastTask
    while (true) {
        const action = yield take(sagaRequestActions)
        if (lastTask) {
            yield cancel(lastTask)
        }
        yield put({type: REFRESH_ARTICLE_DOING})
        switch (action.type) {
            case SAGA_TODAY_ARTICLE:
                lastTask = yield fork(dealtData,action)
                break
            case SAGA_PREV_ARTICLE:
                lastTask = yield fork(dealtData,action)
                break
            case SAGA_NEXT_ARTICLE:
                lastTask = yield fork(dealtData,action)
                break
            case SAGA_RANDOM_ARTICLE:
                lastTask = yield fork(dealtData,action)
                break
        }
    }
}

项目简单明了,而且没有太多复杂的逻辑,可以直接看项目源码

八: 项目地址

九: 分享一个之前写的RN项目

0
0
查看评论

React全家桶之Redux(三)

其实只要你的智商正常,稍微认真学的话,我认为react + react-router 应该三天就可以学好了,但是redux的话.....真的不能保证你能花多久时间学会,只能看你的理解能力如何了。             在准备学R...
  • github_37240941
  • github_37240941
  • 2017-01-19 23:16
  • 728

vue全面介绍--全家桶、项目实例

简介“简单却不失优雅,小巧而不乏大匠”。 2016年最火的前端框架当属Vue.js了,很多使用过vue的程序员这样评价它,“vue.js兼具angular.js和react.js的优点,并剔除了它们的缺点”。授予了这么高的评价的vue.js,也是开源世界华人的骄傲,因为它的作者是位中国人–尤雨溪(...
  • zhenghao35791
  • zhenghao35791
  • 2017-03-28 17:28
  • 46124

【React全家桶入门之十二】Redux介绍

前面的文章中使用了最原始的写法(基于state的状态管理)来完成了一个管理系统。接下来准备给我们的系统引入Redux
  • awaw00
  • awaw00
  • 2017-02-11 17:25
  • 3400

构建vue全家桶项目-构建

1.安装node,下载node并安装 2.检查node与npm版本信息 打开命令行 windows+R node -v      检查node版本 npm -version 检查npm版本 3.开始构建项目 使用命令行进入到工作目录 接着 构建开始   ...
  • museions
  • museions
  • 2017-08-20 21:46
  • 928

重新搭建 React - Redux - Router 完整项目

重新搭建 React - Redux - Router 完整项目 说明 重新看了一遍 React 16.2.0 的文档,针对 react 的变化,以及使用习惯做了重新的总结,上一篇 重新搭建 react 开发环境 已经完成,这里继续针对 react 项目搭建进一步记录。 源码 ...
  • mjzhang1993
  • mjzhang1993
  • 2018-01-10 13:33
  • 193

【React全家桶入门之一】引言

背景之前曾打算写一部“从零开始做一个笑话APP”的React入门系列文章,但是遇到了一些问题:一个完整的App需要去构思App的: 产品功能 逻辑过程 UI设计 还要去完成App需要调用的接口。而这一些工作本并不属于前端的范畴,虽然了解这些在进入工作岗位后能够有所帮助,但是对于初学者来说,首要任务还...
  • awaw00
  • awaw00
  • 2017-01-23 11:32
  • 9128

React+Babel+Webpack初学者全家桶完整实例Demo

写在前面的话自已以前对redux,react,rect-redux,react-router都是有一点的了解,并且在真实的项目中也多少有些涉及。但是不足的地方在于没有做一个demo将他们串起来,所以总是感觉似懂非懂。特别是react服务端渲染这一块,对于自己完全就是一个黑箱,这对我深入理解react...
  • liangklfang
  • liangklfang
  • 2017-06-04 14:09
  • 2732

Vue 全家桶学习资源(持续更新)

companion:React 全家桶学习资源(持续更新)下面整理了一些关于Vue以及Vue衍生的学习资源:官网文档官网APIECMAScript 6 入门30分钟掌握ES6/ES2015核心内容(上)30分钟掌握ES6/ES2015核心内容(下)vuefeVue 中文社区vue-router 2V...
  • u012860063
  • u012860063
  • 2017-03-29 13:49
  • 6903

Vuejs全家桶系列(八)--- 组件

Vuejs全家桶系列(八)--- 组件
  • Nate__River
  • Nate__River
  • 2017-12-22 20:01
  • 201

安卓软件全家桶分析,哪些软件是一伙的

所谓全家桶联盟的意思其实是一个软件联盟的概念, 处于软件联盟中的软件都用了同一个sdk(可以理解为插件), 联盟内软件会在用户不知情的情况下相互调用以保证联盟内的软件在你的手机中时刻保证运行。 意义?1.保证随时能给你发推送。2.后台收集用户数据 一。个推全家桶 代码如下:   ...
  • sinat_32538847
  • sinat_32538847
  • 2015-11-05 18:53
  • 1579
    个人资料
    • 访问:3735次
    • 积分:199
    • 等级:
    • 排名:千里之外
    • 原创:15篇
    • 转载:0篇
    • 译文:0篇
    • 评论:1条
    文章分类
    最新评论