React Native --网络请求,上拉加载,下拉刷新

RN写到现在的心情就是
timg.jpg

各种小问题不断。。。。哎 全是坑啊!!!!!!
好了,收拾一下心情开始嘚吧嘚。

网络工具

React Native提供了和web标准一致的Fetch API,用于满足开发者访问网络的需求;
Fetch的基本用法请移步到RN官网查看 ,这里就不再描述了

请求封装

如今APP端大部分请求都是使用Get或者Post这两种,因此也是对Fetch进行一个简易封装,有点low希望大家指点一下。分为request和config两个文件;request作为网络请求文件,分别封装get和post请求,config最为配置文件,里面放着是api地址,请求头参数配置等

  • request.js文件
/**
 * Created by zhaoruisheng on 2018/2/1.
 */
//严格语法控制
'use strict'

import queryString from 'query-string'
import _ from  'lodash'
import config from './config'


//这里没有类的概念 ,requet就是对象
//requeset是个变量,但后面有个{}  所以是对象
let request ={

}
//设定params  json对象
request.get=(url,params)=> {
    if (params){
        url += '?' + queryString.stringify(params)
    }
    //发送网络请求
    return fetch(url)
        .then((response)=>response.json())
}

request.post=(url,body)=> {
    //合并 json对象
    let map = _.extend(config.map, {
        body:JSON.stringify(body)
    });

    console.log(body);
    console.log(body);
    return fetch(url,map)
        .then((response)=>response.json())
}

module.exports = request;//暴露出去
  • config.js文件
/**
 * Created by zhaoruisheng on 2018/2/1.
 */
'use strict'

const config ={
    api:{
        base:'https://www.baidu.com',//找一个能够使用的域名,这里不提供 
        list:'list'//接口
    },

    map:{
        method: 'POST',
        headers: {
            'Accept': 'application/json;charset=utf-8',//根据自己服务器返回数据格式设定,设定错误,数据返回类型不对
            'Content-Type': 'application/json;charset=utf-8',
        },
        timeout:8000,
    }
}

module.exports = config
  • listView
    在RN中的ListView组件使用法法和iOS中的很像
<ListView
                    dataSource={this.state.dataSource}
                    renderRow={this._renderRow}
                    style={styles.listView}
                    onEndReached={this._fetchMoreData} //加载到底部触发
                    onEndReachedThreshold={20}//加载到距离底部还有多远触发
                    renderFooter={this._renderFooter}//footerView自定义一个视图 
   
</ListView>

在状态机中添加dataSource,用来实时更新数据

dataSource:new  ListView.DataSource({
                rowHasChanged:(r1,r2)=>r1!==r2,//这句代码是用来控制item数据的更新,当且仅当任意两行数据不相等时才去更新数据源。这里是RN中的一个性能优化。
            }),

网络请求成功后会刷新数据

//发送网络请求
        request.post(config.api.base+config.api.list,{
            classCode:101101,
            pageSize:15,
            pageNo:page
        }).then(
            (data) => {

                if (data.code == 200){
                    console.log(data)
                    //将服务器得到的数据缓存起来
                    dataSource:this.state.dataSource.cloneWithRows(
                                data.list;
                            ),
                        });
            }
        )
上拉加载

ListView中自带有上拉加载属性

onEndReached={this._fetchMoreData} //加载到底部触发
onEndReachedThreshold={20}//加载到距离底部还有多远触发
renderFooter={this._renderFooter}//footerView自定义一个视图

添加_fetchMoreData方法,用来实现上拉加载,实现上拉加载的方法有很多,大多根据业务需求,还有添加一些用户体验,例如:在网络比较差的时候,用户可能比较着急,请求数据还没返回来,然后又在滑动屏幕,进行了上拉加载操作,又进行了下拉刷新操作,多次操作后,数据返回比较混乱,因此进行体验优化,
总共分为3步走

  • 1、发送网络请求
  • 2、保存请求参数
  • 3、参数对比
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,128评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,316评论 3 388
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,737评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,283评论 1 287
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,384评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,458评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,467评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,251评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,688评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,980评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,155评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,818评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,492评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,142评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,382评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,020评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,044评论 2 352

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 171,945评论 25 707
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,644评论 18 139
  • 1.ios高性能编程 (1).内层 最小的内层平均值和峰值(2).耗电量 高效的算法和数据结构(3).初始化时...
    欧辰_OSR阅读 29,353评论 8 265
  • 你别老想这老想那了 累啊 工作的时候认真工作 学习就好好学习 一切糟糕都会过去的 少年 嗯 没关系的
    一棵叫2046的树阅读 144评论 0 1
  • 我们都应该过的是以后。 以前,以前重要,以前塑造了现在的我们,但它不能决定以后的我们。 我做过很多很多的错事,也很...
    彧愔从阅读 253评论 0 0