React Native 解决RenderRow只渲染一次

本文介绍了一种在React Native中使用ListView组件时更新数据的方法。具体包括如何通过rowHasChanged函数判断数据变化、如何利用状态机保存数据并进行数组拼接以实现数据更新,以及如何重置数据源。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

数据源判断, rowHasChanged的时候数据源可变

 let ds = new ListView.DataSource({
            rowHasChanged: (r1, r2) => (r1, r2) => {
                return r1 !== r2;
            }
        });

状态机声明一个数组保存每次。请求下来的数据,利用concat拼接数组

// 状态机声明空数组
 this.state = {
     dataArray: []
 }

网络请求拼接数组

let oldArray = this.state.dataArray;
let newArray = [];
newArray = oldArray.concat(json.data.list)
 this.setState({
     dataSource: dataSource.cloneWithRows(newArray),                    
     dataArray: newArray
 })

重置数据源,通过Object.assign,让renderRow渲染

 let dataArray = Object.assign({}, this.state.dataArray)
        this.setState({
            dataSource: this.state.dataSource.cloneWithRows(dataArray)
        })
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值