Ich bin neu in React und ich versuche, eine Tabelle von Benutzern zu erstellen und Checkboxen zu verwenden, um ihre Berechtigungen zu verwalten. Ich habe ein Problem mit der Aktualisierung des Status beim Klicken auf ein Kontrollkästchen festgestellt. Die HandleChange-Methode ist, wo ich Probleme habe. Ich weiß nicht, wie ich das richtige Kontrollkästchen anwählen soll, um den Status für diesen bestimmten Benutzer zu ändern. Ich denke, vielleicht muss ich jedem einen ID-Prop hinzufügen, aber das scheint für eine große Anzahl von Benutzern außer Kontrolle zu geraten, d. H. Eine ID für jede Erlaubnis pro Benutzer. Ich denke, das sollte nicht so schwierig sein, aber ich stecke seit langem fest.Wie verwaltet man den Status mit Checkboxen in React?
Mein Komponentencode ist unten.
import React from 'react'
import {Link} from 'react-router'
import {Panel, Button, PageHeader, Row, Col, Table, Input} from 'react-bootstrap'
export class UserPermissions extends React.Component {
constructor() {
super();
this.state = {
users: [
{
name: 'Jerry',
viewAccounts: true,
modifyAccounts: true,
viewUsers: false,
modifyUsers: true
},
{
name: 'George',
viewAccounts: false,
modifyAccounts: true,
viewUsers: false,
modifyUsers: false
},
{
name: 'Elaine',
viewAccounts: true,
modifyAccounts: false,
viewUsers: false,
modifyUsers: true
}
]
}
}
handleChange(e){
//not sure how to write this
}
renderHeadings(data){
return data.map((step, index) => <th key={index} style={{align:"center"}}>{step}</th>);
}
renderRows(data){
return data.map((step, index) =>
<tr key={index}>
<td>{step['name']}</td>
<td style={{align:"center", paddingLeft:"40px"}}>
<Input type="checkbox"
checked={step['viewAccounts']}
onChange={this.handleChange}/></td>
<td style={{align:"center", paddingLeft:"40px"}}>
<Input type="checkbox"
checked={step['modifyAccounts']}
onChange={this.handleChange}/></td>
<td style={{align:"center", paddingLeft:"40px"}}>
<Input type="checkbox"
checked={step['viewUsers']}
onChange={this.handleChange}/></td>
<td style={{align:"center", paddingLeft:"40px"}}>
<Input type="checkbox"
checked={step['modifyUsers']}
onChange={this.handleChange} /></td>
<td style={{align:"center"}}>
<Link to="/users"><i className="fa fa-edit fa-2x fa-fw" /></Link>
<Link to="/users"><i className="fa fa-times-circle fa-2x fa-fw" /></Link></td>
</tr>
);
}
render() {
return (
<div>
<Row>
<Col lg={12}>
<PageHeader>User Permissions</PageHeader>
</Col>
<Col lg={12}>
<Panel header={<span>Users</span>} bsStyle="primary">
<div>
<div className="dataTable_wrapper">
<div id="dataTables-example_wrapper" className="dataTables_wrapper form-inline dt-bootstrap no-footer">
<Row>
<Col sm={12}>
<Table striped condensed responsive>
<thead>
<tr>
{this.renderHeadings(this.props.headings)}
</tr>
</thead>
<tbody>
{this.renderRows(this.state.users)}
</tbody>
</Table>
</Col>
</Row>
</div>
</div>
</div>
</Panel>
<Button bsStyle="success">Add User</Button>
</Col>
</Row>
</div>
);
}
}
UserPermissions.propTypes = {
headings: React.PropTypes.array
}
UserPermissions.defaultProps = {
headings: ['Name', 'View Accounts', 'Modify Accounts', 'View Users', 'Modify Users']
}
Anruf Griff Wechsel mit Schrittwert wie: 'this.handleChange (‚modifyUsers‘)' oder können Sie 'refs' das Kontrollkästchen zu identifizieren. –