React Native 0.32 似乎有一个错误。以下代码在 0.20 和 0.24 中运行良好,如您在 RN Play 链接中所见。
https://rnplay.org/apps/W5k6Xg
'use strict';
var React = require('react');
var ReactNative = require('react-native');
var {
AppRegistry,
ListView,
StyleSheet,
Text,
View,
Image
} = ReactNative;
var GridLayoutExample = React.createClass({
getInitialState: function() {
var ds = new ListView.DataSource({rowHasChanged: (r1, r2) => r1 !== r2});
return {
dataSource: ds.cloneWithRows([
{ name: 'John', image: 'https://d30y9cdsu7xlg0.cloudfront.net/png/619232-84.png' },
{ name: 'Joel', image: 'https://d30y9cdsu7xlg0.cloudfront.net/png/619230-84.png' },
{ name: 'James', image: 'https://d30y9cdsu7xlg0.cloudfront.net/png/619168-84.png' },
{ name: 'Jimmy', image: 'https://d30y9cdsu7xlg0.cloudfront.net/png/619130-84.png' },
{ name: 'Jackson', image: 'https://d30y9cdsu7xlg0.cloudfront.net/png/619098-84.png' },
{ name: 'Jillian', image: 'https://d30y9cdsu7xlg0.cloudfront.net/png/618793-84.png' },
{ name: 'Julie', image: 'https://d30y9cdsu7xlg0.cloudfront.net/png/618803-84.png' },
{ name: 'Devin', image: 'https://d30y9cdsu7xlg0.cloudfront.net/png/618706-84.png' }
])
};
},
render: function() {
return (
// ListView wraps ScrollView and so takes on its properties.
// With that in mind you can use the ScrollView's contentContainerStyle prop to style the items.
<ListView contentContainerStyle={styles.list}
dataSource={this.state.dataSource}
renderRow={this._renderRow}
/>
);
},
_renderRow: function(rowData: string, sectionID: number, rowID: number) {
return (
<View>
<View style={styles.row}>
<Image style={styles.thumb} source={{uri: rowData.image}} />
<Text style={styles.text}>
{rowData.name}
</Text>
</View>
</View>
);
}
});
var styles = StyleSheet.create({
list: {
justifyContent: 'center',
flexDirection: 'row',
flexWrap: 'wrap',
backgroundColor: "blue"
},
row: {
justifyContent: 'center',
padding: 5,
width: 100,
height: 100,
backgroundColor: '#F6F6F6',
borderWidth: 1,
borderColor: '#CCC',
alignItems: 'center'
},
thumb: {
width: 64,
height: 64
},
text: {
marginTop: 5,
fontWeight: 'bold'
}
});
AppRegistry.registerComponent('SampleApp', () => GridLayoutExample);
预期输出(如您在带有 React Native 0.24.1 的 RNPlay 上看到的那样):
我看到的(React native 0.32):
请帮我解决这个问题。
最佳答案
您应该将 alignItems: 'flex-start'
添加到您的 list
样式中。
list: {
justifyContent: 'center',
flexDirection: 'row',
flexWrap: 'wrap',
alignItems: 'flex-start',
backgroundColor: "blue"
},
React Native 0.28 中发生了重大变化改变了 flex-wrap
的行为:
Due to performance tweaks
flexWrap: wrap
no longer works together withalignItems: 'stretch'
(the default). If you useflexWrap: wrap
you probably will want to add thealignItems: 'flex-start'
style as well.
关于ios - react native GridView : Flexbox wrap not working,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39313268/