我正在学习对本机立即做出反应,并对它的工作方式产生新的反应。我目前正在做一个项目,试图对它进行一些修改。 https://github.com/denodenodeno/employee
该项目的底部有一个标签栏,我想将其更改为顶部的分段控件。结果就是我所做的和得到的。
带有标签栏的原始代码
import React, {Component} from 'react';
import {
StyleSheet,
TabBarIOS
} from 'react-native';
import {bind} from '../utils/utils';
import EmployeesTab from './EmployeesTab';
import SearchTab from './SearchTab';
const employeesIcon = '';
class App extends Component {
constructor(props, context) {
super(props, context);
this.state = {
selectedTab: 'employees'
};
bind(this)('_searchOnPress', '_employeesOnPress');
}
_employeesOnPress() {
this.setState({
selectedTab: 'employees'
})
}
_searchOnPress() {
this.setState({
selectedTab: 'search'
})
}
render() {
return (
<TabBarIOS
selectedTab={this.state.selectedTab}>
<TabBarIOS.Item
title="Employees"
selected={this.state.selectedTab === 'employees'}
icon={{uri: employeesIcon, scale: 3}}
onPress={this._employeesOnPress}>
<EmployeesTab />
</TabBarIOS.Item>
<TabBarIOS.Item
title="Search"
selected={this.state.selectedTab === 'search'}
systemIcon="search"
onPress={this._searchOnPress}>
<SearchTab />
</TabBarIOS.Item>
</TabBarIOS>
)
}
}
尝试分段控制
我更改了渲染器中的片段并返回到此
<SegmentedControlIOS
values={['Employees', 'Search']}
selectedIndex={0}
tintColor={'#D6573D'}
onValueChange={(val) => {
if (val === "Employees"){
this._employeesOnPress;
}
else if (val === "Search") {
this._searchOnPress;
}}}
onChange={(val) => {
if (val === "Employees"){
<EmployeesTab />
}
else if (val === "Search") {
<SearchTab />
}}}
/>
这给了我this segmented control with nothing else rendered
我不了解这个问题。任何帮助,将不胜感激!谢谢
答案 0 :(得分:0)
您不能在道具内部渲染JSX
,而是可以在状态下基于value
渲染组件。如:
<SegmentedControlIOS
values={['Employees', 'Search']}
selectedIndex={0}
tintColor={'#D6573D'}
onValueChange={(val) => this.setState({ selectedTab: val})}
/>
{this.state.selectedTab === 'Employees' ? <EmployeesTab /> : <SearchTab /> }