获取反应原生的CheckBox工作/渲染的任何简单示例?这就是CheckBox,它现在似乎是本地提到的react-native的一部分:http://facebook.github.io/react-native/docs/checkbox.html
mag*_*icz 18
目前CheckBox组件仅在Android上受支持.正如这里所说,对于iOS,你应该使用Switch.
对于Android,使用非常简单.
<View style={{ flexDirection: 'column'}}>
<CheckBox />
<View style={{ flexDirection: 'row' }}>
<CheckBox
value={this.state.checked}
onValueChange={() => this.setState({ checked: !this.state.checked })}
/>
<Text style={{marginTop: 5}}> this is checkbox</Text>
</View>
</View>
Run Code Online (Sandbox Code Playgroud)
View和Text组件是可选的,只是为了展示CheckBox如何与它们一起使用.上面的代码将在Android设备上生成此屏幕.

这在iOS设备上
小智 18
您可以创建自己的。
您将需要安装 react-native-vector-icons (或者您可以使用图像)。
yarn add react-native-vector-icons
react-native link react-native-vector-icons
Run Code Online (Sandbox Code Playgroud)
创建文件组件/CheckBox/index.js
import React from 'react'
import Icon from 'react-native-vector-icons/MaterialIcons'
import styles from './styles'
import { TouchableOpacity, Text } from 'react-native'
const CheckBox = ({ selected, onPress, style, textStyle, size = 30, color = '#211f30', text = '', ...props}) => (
<TouchableOpacity style={[styles.checkBox, style]} onPress={onPress} {...props}>
<Icon
size={size}
color={color}
name={ selected ? 'check-box' : 'check-box-outline-blank'}
/>
<Text style={textStyle}> {text} </Text>
</TouchableOpacity>
)
export default CheckBox
Run Code Online (Sandbox Code Playgroud)
创建文件 components/CheckBox/styles.js
import { StyleSheet } from 'react-native'
const styles = StyleSheet.create({
checkBox: {
flexDirection: 'row',
alignItems: 'center'
}
})
export default styles
Run Code Online (Sandbox Code Playgroud)
使用方法
import React, { Component } from 'react'
import styles from './styles'
import { CheckBox } from '../../components'
import { View } from 'react-native'
class Signup extends Component {
state = {
termsAccepted: false
}
handleCheckBox = () => this.setState({ termsAccepted: !this.state.termsAccepted })
render() {
return (
<View style={{}}>
<CheckBox
selected={this.state.termsAccepted}
onPress={this.handleCheckBox}
text='Accept terms and conditions'
/>
</View>
)
}
}
export default Signup
Run Code Online (Sandbox Code Playgroud)
对于不了解上述答案的初学者
import React, { Component } from 'react';
import { Platform, View, Text, CheckBox } from 'react-native';
var tempCheckValues = [];
export default class App extends Component {
constructor(props) {
super(props);
this.state = {
checkBoxChecked: []
}
}
checkBoxChanged(id, value) {
this.setState({
checkBoxChecked: tempCheckValues
})
var tempCheckBoxChecked = this.state.checkBoxChecked;
tempCheckBoxChecked[id] = !value;
this.setState({
checkBoxChecked: tempCheckBoxChecked
})
}
render() {
const products = [{
id: 1
},
{
id: 2
},
{
id: 3
}];
return (
products.map((val) => {
{ tempCheckValues[val.id] = false }
return (
<View key={val.id} style={{ flexDirection: 'column' }}>
<CheckBox
value={this.state.checkBoxChecked[val.id]}
onValueChange={() => this.checkBoxChanged(val.id, this.state.checkBoxChecked[val.id])}
/>
</View >
)
}
)
);
}
}
Run Code Online (Sandbox Code Playgroud)
使用react-native-elements,任务更容易并且示例可用:
import { CheckBox } from 'react-native-elements'
<CheckBox
title='Click Here'
checked={this.state.checked}
/>
<CheckBox
center
title='Click Here'
checked={this.state.checked}
/>
<CheckBox
center
title='Click Here'
checkedIcon='dot-circle-o'
uncheckedIcon='circle-o'
checked={this.state.checked}
/>
<CheckBox
center
title='Click Here to Remove This Item'
iconRight
iconType='material'
checkedIcon='clear'
uncheckedIcon='add'
checkedColor='red'
checked={this.state.checked}
/>
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
46986 次 |
| 最近记录: |