数字1,2,3の完全な配列があります。スクエアコンポーネントをレンダリングするために、各番号の上にマップしようとしています。これはうまくいった。今度は、値(1,2、または3)に応じて、Squareコンポーネントの条件付きスタイルを設定します。私は 'switch'(Unexpected token)という行にシンタックスエラーがあり、その理由を見つけることができないようです。React-Native:子コンポーネントの条件付きスタイル設定
class MainMaze extends Component {
generateMaze() {
const { tiles, cols, rows } = this.props.grid;
return (
tiles.map((sq, i) =>
switch (sq) {
case 3:
return <Square style={{ backgroundColor: 'red' }}>{sq}</Square>;
case 2:
return <Square style={{ backgroundColor: 'blue' }}>{sq}</Square>;
default:
return <Square style={{ backgroundColor: 'green' }}>{sq}</Square>;
}
);
}
render() {
const { grid, position, status } = this.props;
return (
<View>
<CardSection>
<Text>{grid.cols}</Text>
</CardSection>
<CardSection>
{this.generateMaze()}
</CardSection>
</View>
);
}
}
const mapStateToProps = (state) => {
return {
status: state.status,
position: state.position,
grid: state.grid
};
};
export default connect(mapStateToProps)(MainMaze);
スクエアコンポーネント:
import React from 'react';
import { View, Text } from 'react-native';
const Square = (props) => {
return (
<View style={[styles.containerStyle, props.style]}>
<Text>
{props.children}
</Text>
</View>
);
};
const styles = {
containerStyle: {
borderWidth: 1,
borderColor: '#ddd',
elevation: 1,
alignItems: 'center',
justifyContent: 'center',
margin: 0,
height: 30,
width: 30
}
};
export { Square };
「Square」コンポーネントからの小道具にアクセスできますか?つまり、あなたの小道具は「Square」コンポーネントにありますか?ありがとうございました。 –