RN-第三方控件示例

RN-第三方之react-native-pull-下拉刷新、上拉

2017-04-18  本文已影响4804人  精神病患者link常

有一个很好的下拉刷新、上拉加载库:react-native-pull
地址:https://github.com/greatbsky/react-native-pull-demo

下载

npm install react-native-pullview --save

使用

import {PullList} from 'react-native-pull';//PullList相当于ListView

源码地址:https://github.com/greatbsky/react-native-pull-demo/blob/master/PullListDemo/app.js


import {PullView} from 'react-native-pull';//PullView相当于ScrollView

源码地址:https://github.com/greatbsky/react-native-pull-demo/blob/master/PullViewDemo/app.js

下载好库直接复制上面网址里面的代码就可以看到效果,使用简单

PullList使用

8DCB05BD-83CD-4D77-8BB4-AD1626C2876D.png

在对应的方法里进行相应的操作即可

自定义顶部的方法

2CF30377-991B-40CD-BF02-C8627F5189FA.png

在下拉到完成时,上面的方法是不停地调用的
有三个参数
下拉:pulling=true,pullok=false,pullrelease=false
到达临界点:pulling=false,pullok=true,pullrelease=false
释放:pulling=false,pullok=false,pullrelease=true

可以根据这三个参数判断什么时候显示什么样的界面
上图是官方的例子(说实话,我这种小白就喜欢简单粗暴的,上面的代码表示完全看不懂)

以下是我自己写的,简单到词穷
在view里面放一个Text,通过state改变Text的文本,更复杂就自己干吧

onPullOk(){
        //只要拉倒那个临界点,就会调用该方法
        console.log('onPullOk');
        this.setState({
            loadText:'释放刷新'
        });

    }
    onPulling(){
        //下拉时调用
        console.log('onPulling');

        this.setState({
           loadText:'下拉刷新',
        });
    }
    onPullRelease(resolve) {
        //松开手指刷新调用
        console.log('onPullRelease');
        this.setState({
            loadText:'正在刷新',
            isRefreshing:false,
            isLoadEnd:false,

        });


        setTimeout(() => {
            // 准备下拉刷新的5条数据
            var data=this.state.dataSource;

            let arr= Array.from(new Array(5)).map((item,index)=>{
                return ('row:'+{index})

            }).concat(data);


            this.setState({
                isRefreshing: true,
                dataSource: arr,
                loadText:'下拉刷新',
                isLoadEnd:true,
            });


            //回到原始状态
            resolve();


        }, 2000);
    }
PullView使用

和pullList使用一样的,多的就不写了

16E18506-807F-4D4C-9F1E-AA3DAB893EC3.png

上拉加载主要就是这个

                    //React Native中文网注释如下:
                    // 当所有的数据都已经渲染过,并且列表被滚动到距离最底部不足onEndReachedThreshold个像素的距离时调用。
                    // 原生的滚动事件会被作为参数传递。




                    // 译注:当第一次渲染时,如果数据不足一屏(比如初始值是空的),这个事件也会被触发,请自行做标记过滤。




                    onEndReached={this.loadMore}
                    onEndReachedThreshold={60}

大概和iOS的差不多,滚动到倒数第几个cell的时候,请求下一页的数据,这里只不多是换成了距离底部多少距离而已

同时也看了RN上面的 RefreshControl 刷新,也只是做了个小例子,使用更加简单
(下方title,tintColor 标注错误,tintColor为菊花颜色,都是iOS可用)

D188CD9D-01E7-4E0E-A30C-EB0CC7C02B28.png QQ20170418-150133.gif

demo:
看效果可以在 idnex.ios.js里面改变跳转的页面

9D7C4534-E0FB-4DFE-B1C1-FF4C89C3EC5B.png
上一篇 下一篇

猜你喜欢

热点阅读