我这样做是为了获得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的新手。
先谢谢了。