• ReactNative: 使用刷新组件RefreshControl组件


    一、简介

    刷新功能在数据更新的时候很常用,它对用户有一个非常明显的数据正在更新的提示信息。ReactNative中提供了RefreshControl组件来实现这个刷新功能。在前面介绍的ScrollView或ListView,都支持刷新组件的使用,可添加拉动刷新功能。

    二、API

    它是跨平台的组件,提供的属性如下:

    //视图下拉开始刷新时调用。
    onRefresh: React.PropTypes.func
    
    //该视图是否应指示活动刷新。
    refreshing: React.PropTypes.bool.isRequired
    
    //刷新指示器的颜色。@platform ios
    tintColor: ColorPropType
    
    //刷新文案的颜色。@platform ios
    titleColor: ColorPropType
    
    //标题显示在刷新指示器下方。@platform ios
    title: React.PropTypes.string
    
    //是否启用拉动刷新功能。@platform android
    enabled: React.PropTypes.bool
    
    //用于绘制刷新指示器的颜色(至少一种)。@platform android
    colors: React.PropTypes.arrayOf(ColorPropType)
    
    //刷新指示器的背景色。@platform android
    progressBackgroundColor: ColorPropType
    
    //刷新指示器的大小,请参见RefreshControl.SIZE。@platform android
    size: React.PropTypes.oneOf([RefreshLayoutConsts.SIZE.DEFAULT, RefreshLayoutConsts.SIZE.LARGE])
    
    //进度视图顶部偏移。@platform android
    progressViewOffset: React.PropTypes.number

    三、使用

    了解了api,简单示例如下:

    ScrollRefreshControl.js

    import React, { Component } from 'react';
    
    import {
        StyleSheet,
        ScrollView,
        Text,
        RefreshControl
    } from 'react-native';
    
    export default class ScrollRefreshControl extends Component{
    
        //state数据
        state = { text: '初始状态', refreshing: false };
    
        //下拉视图开始刷新时调用
        _onRefresh() {
    
            if (this.state.refreshing === false) {
                this._updateState('正在刷新......', true);
    
                //5秒后结束刷新
                setTimeout( ()=>{
                    this._updateState('结束状态', false)
                }, 5000)
    
            }
        }
    
        //更新State
        _updateState(message, refresh){
            this.setState({text:message,refreshing: refresh});
        }
    
        render(){
            return (
                <ScrollView
                    style={[styles.flex,styles.bgColor]}
                    contentContainerStyle={{flex: 1, alignItems: 'center',justifyContent: 'center'}}
                    indicatorStyle={'black'}
                    showsHorizontalScrollIndicator={true}
                    bounces={true}
                    refreshControl={
                        <RefreshControl
                            tintColor={'red'}
                            titleColor={'brown'}
                            title={'正在刷新......'}
                            refreshing={this.state.refreshing}
                            onRefresh={this._onRefresh.bind(this)}
                        />
                    }
                >
                    <Text>{this.state.text}</Text>
                </ScrollView>
            )
        }
    }
    
    const styles = StyleSheet.create({
        flex: {
            flex: 1
        },
        bgColor: {
            backgroundColor:'#EEE'
        }
    });

    index.ios.js

    /**
     * Sample React Native App
     * https://github.com/facebook/react-native
     * @flow
     */
    
    import React, { Component } from 'react';
    
    import {
        AppRegistry,
        StyleSheet,
        View
    } from 'react-native';
    import ScrollRefreshControl from "./src/ScrollRefreshControl";
    
    
    export default class ReactNativeDemo extends Component {
    
        render() {
            return (
                <View style={[styles.flex,styles.bgColor]}>
                    <ScrollRefreshControl/>
                </View>
            );
        }
    }
    
    const styles = StyleSheet.create({
        flex: {
            flex: 1
        },
        bgColor: {
          backgroundColor: 'white'
        }
    });
    
    AppRegistry.registerComponent('ReactNativeDemo', () => ReactNativeDemo);

  • 相关阅读:
    【工作感悟】2022年8月23日
    [Anaconda]查看anaconda的方法
    [MACOS]BOOKS
    Mac_每次都要执行source ~/.bash_profile 配置的环境变量才生效
    [Anaconda]查看当前已经激活的anaconda的方法
    解决:DeprecationWarning: executable_path has been deprecated, please pass in a Service object
    [BREW]如何在MAC上安装Consolas
    20220917
    对net5.0的理解
    如何做到高效CI/CD
  • 原文地址:https://www.cnblogs.com/XYQ-208910/p/12160887.html
Copyright © 2020-2023  润新知