在本机反应中获得两个不同的状态值

时间:2019-07-01 15:50:21

标签: react-native onpress

我这样做是为了获得Flatlist中元素的多个选择。在下面的代码中,我标记了两行。

let isSelected = this.state.selectedItems.includes(index)

alert(selectedItems+ " Are selected " + isSelected + this.state.selectedItems.includes(index) );

每行具有不同的值。

import React, { Component } from 'react';
import {
  StyleSheet,
  Text,
  StatusBar ,
  TouchableOpacity,
  View,
  FlatList,
  ActivityIndicator,
  TouchableHighlight,
  PropTypes,
  Image,
  Alert,
} from 'react-native';

import Logo from '../components/Logo';
import Form from '../components/Front';

import {Actions} from 'react-native-router-flux';

export default class Login extends Component<{}> {
  constructor(props) {
    super(props);
    this.state = {
      dataSource: [],
      pressed: false,
      selected_category: '',
      black: '',
      selectedItems: [],
    };
  }
  _handleCategorySelect = (index) => { 
    this.setState({selected_category: index}); 
  }
  _onPress = () => {
    this.props.onPressItem(this.props.id);
  }
  izijackpotconfirm() {
      Actions.izijackpotconfirm()
  }
  componentDidMount() {
    var that = this;
    let items = Array.apply(null, Array(25)).map((v, i) => {
      return { id: i+1, index: i };
    });
    that.setState({
      dataSource: items,
    });
  }
  _renderItems = ({item, index}) => {

    let isSelected = this.state.selectedItems.includes(index)

     return(
        <View style={{ flex: 1, flexDirection: 'column', margin: 1 }}>
          <TouchableOpacity
            onPress={() => {

               let ind = this.state.selectedItems.indexOf(index)
               let selectedItems = this.state.selectedItems
               if(isSelected && index === ind) {
                 selectedItems.splice(ind, 1) 
               } else {
                 selectedItems.push(index)
               }

               this.setState({selectedItems:selectedItems})
               alert(selectedItems+ " Are selected " + isSelected);
            }}
            style={isSelected ?  
               styles.pressed : styles.iziPizi}
            onHideUnderlay={() => {
                this.setState({ pressed: false });
            }}
            onShowUnderlay={() => {
                this.setState({ pressed: true });
            }}
            underlayColor={'gray'}
          >
              <Text style={styles.buttonText}>{ item.id}</Text> 
          </TouchableOpacity>
       </View>
     )
  }
 static navigationOptions = {
    title: "Izi Jackpot",
    headerStyle: {
      backgroundColor: "#354247"
    },
    headerTintColor: "#fff",
    headerTitleStyle: {
      fontWeight: "bold"
    }
  };
    render() {

    var jackpotNumbers = [];
    let btn_class = this.state.black ? "NormalSet" : "SelectedSet";
    const textColor = this.props.selected ? 'red' : 'black';
        return(
      <View style={styles.container}>
        <View style={styles.middlecontainer}>
          <Text style={styles.logoText}>Please Select 5 Numbers and Submit</Text>
        </View>
        <FlatList
           data={this.state.dataSource}
           extraData={this.state.selectedItems}
           ref={(e) => this.items = e}
           renderItem={this._renderItems}
           numColumns={5}
           keyExtractor={(item, index) => index}
        />

        <View style={styles.middlecontainer}>
         <TouchableOpacity style={styles.button} onPress={this.izijackpotconfirm} >
           <Text style={styles.buttonText}>Submit</Text>
         </TouchableOpacity>     
        </View>
      </View>

            )
    }
}
const styles = StyleSheet.create({
  container : {
    backgroundColor:'#6F9000',
    justifyContent: 'center',
    flex: 1,
    paddingTop: 30,

  },
  middlecontainer: {
    textAlign: 'center',
    alignItems: 'center',
    justifyContent :'center',
    flex:1    
  },
  signupTextCont : {
    flexGrow: 1,
    alignItems:'flex-end',
    justifyContent :'center',
    paddingVertical:16,
    flexDirection:'row'
  },
  signupText: {
    color:'rgba(255,255,255,0.6)',
    fontSize:16
  },
  signupButton: {
    color:'#ffffff',
    fontSize:16,
    fontWeight:'500'
  },
  iziPizi: {
    width: 55,
    padding: 15,
    margin: 5,
    backgroundColor: 'rgba(255,255,255,0.6)',
    borderRadius: 80,
    borderWidth: 2,
    borderColor: '#FFFFFF',
    flex:1
  },
  pressed: {
    width: 55,
    padding: 15,
    margin: 5,
    backgroundColor:'#1c313a',
    borderRadius: 80,
    borderWidth: 2,
    borderColor: '#FFFFFF',
    flex:1
  },
  button: {
    width:300,
    backgroundColor:'#1c313a',
     borderRadius: 25,
      marginVertical: 10,
      paddingVertical: 13
  },
  buttonText: {
    fontSize:16,
    fontWeight:'500',
    color:'#ffffff',
    textAlign:'center'
  },
  logoText : {
    color:'#FFFFFF',
    fontSize: 16,
    fontWeight: '500',
    alignItems: 'center',
    justifyContent:'center',
  },
  imageThumbnail: {
    justifyContent: 'center',
    alignItems: 'center',
    height: 100,
  },
});

我想从上面获得this.state.selectedItems.includes(index)。但是在我打印时它显示true。如果我从上面打印“ isSelected”,它将打印false。我想知道如何获取值true

实际上,我想通过onPress在代码中选择多个元素。那我该怎么办呢?请帮我。我是React Native的新手。

先谢谢了。

0 个答案:

没有答案