对清单上的单个项目进行动画处理

时间:2019-09-20 15:16:51

标签: react-native react-native-flatlist

我如何为单位列表中的单个项目设置动画?

我尝试添加一个值来隔离所选记录,但是没有用,也许我写错了。 atm动画在所有记录上

平面列表:

 <View style={style.container}>
                <FlatList
                    data={this.state.ReturnedArray}
                    width='100%'
                    ItemSeparatorComponent={this.FlatListItemSeparator}
                    renderItem={this.renderizza}>

渲染Flalist:

renderizza = (item) => {
        var str = JSON.parse(JSON.stringify(item.item.itemType)).name + ' ' + JSON.parse(JSON.stringify(item.item.itemType)).cognome
        let acronym = str.split(/\s/).reduce((response, word) => response += word.slice(0, 1), '')
        return (
            <View style={style.containerFlat}>
                <View style={style.containerFlat1}>    
                    <Text style={style.txt}>{JSON.parse(JSON.stringify(item.item.itemType)).name} {JSON.parse(JSON.stringify(item.item.itemType)).cognome}</Text>
                </View>
               <TouchableOpacity style={style.containerFlat2} onPress={() => this.badge(JSON.parse(JSON.stringify(item.item.itemType)).expoToken)}> 
                    <Animated.View style={[style.animatedView, { opacity: this.state.fadeValue}]}><Text>ADDED</Text></Animated.View>
                    <Text style={style.AvatarTxt}  >{acronym}</Text>
                </TouchableOpacity>
            </View>
        )
    }

还有动画:

    badge(chiavi) {
        console.log(chiavi)
        if ((this.state.SelectedUser).includes(chiavi)) {
            this.state.SelectedUser.splice(this.state.SelectedUser.indexOf(chiavi), 1)
            Animated.timing(this.state.fadeValue, {
                toValue: 0,
                duration: 0
            }).start();
        } else {
            this.state.SelectedUser.push(chiavi)
            Animated.timing(this.state.fadeValue, {
                toValue: 1,
                duration: 0
            }).start()
        }
    }

热修复? 谢谢

1 个答案:

答案 0 :(得分:0)

一种方法是将活动项目保持在状态,并在extraData中为此变量使用Flatlist道具。然后有条件地在动画项目和普通项目之间进行渲染。

animate = index => {
    this.setState({
      activeItem: index,
    });
     //Rest of animation code.
  };

<TouchableOpacity onPress={e => this.animate(index)}>
   {this.state.activeItem === index && (
      <Animated.View
         style={[
                styles.button,
                { transform: [{ scale: this.animationMap }] },
                ]}
      >
        <Text>{item.title}</Text>
      </Animated.View>
      )
   }
   {this.state.activeItem !== index && (
          <View style={styles.button}>
            <Text>{item.title}</Text>
          </View>
        )
   }
 </TouchableOpacity>

这是一个示例Demo