Раствор 1
Если вы хотите напрямую рассчитать видимую высоту окна, вы можете использовать обратный вызов onLayout, например, для навигации по вкладкам на каждой странице,
render() {
return (
<View style={{ flex: 1}} onLayout={(event) => {
var {x, y, width, height} = event.nativeEvent.layout;
this.viewableWindowHeight=height;
// use height as viewableWindowHeight
}} />
<ScollView>
//Your scrollable contant
</ScrollView>
</View>
);
Раствор 2
В соответствии с проблемой в реагирующей навигации вы не можете напрямую рассчитать высоту нижней вкладки «Панель». Но если вы поместите нижнюю панель вкладок в представление, а затем сможете рассчитать высоту этих представлений как нижнюю панель вкладок. Рассмотрим пример ниже
import React, { Component } from 'react';
import { connect } from 'react-redux';
import { View } from 'react-native';
import { BottomTabBar } from 'react-navigation';
class TabBarComponent extends Component {
measure = () => {
if (this.tabBar) {
this.tabBar.measureInWindow(this.props.setTabMeasurement);
}
}
render() {
return (
<View
ref={(el) => { this.tabBar = el; }}
onLayout={this.measure}
>
<BottomTabBar {...this.props} />
</View>
);
}
}
function mapDispatchToProps(dispatch) {
return {
setTabMeasurement: (x, y, width, height) => dispatch({
type: 'SET_TAB_MEASUREMENT',
measurement: {
x, y, width, height,
},
}),
};
}
export default connect(null, mapDispatchToProps)(TabBarComponent);