我正在尝试在React JSX中设置一个切换按钮。当我单击订单详细信息切换按钮时,我希望切换仅针对所选订单打开。
现在,我能够做到。但是也会打开其他内容卡(反应引导卡)。没有显示其他卡的订单详细信息,这很好,但是它们的包装盒却被奇怪地拉长了。
请参见下面:
在上面的示例中,仅应打开与订单ID 2相关的卡。其他三张卡应保留其原始大小。
下面是我在前端的React代码:
import React from 'react'
import {connect} from 'react-redux'
import {toDollars, getOrders} from '../store/allOrders' // sortOrders
import {updateOrderThunk, fetchSingleOrder} from '../store/singleOrder'
// Status Filter import BeerFilter from './BeerFilter'
import Card from 'react-bootstrap/Card'
import Button from 'react-bootstrap/Button'
import {UncontrolledCollapse, CardBody} from 'reactstrap'
export class AllOrders extends React.Component {
constructor(props) {
super(props)
this.state = {
showForm: false,
stat: ''
}
this.clickHandlerOne = this.clickHandlerOne.bind(this)
this.handleChange = this.handleChange.bind(this)
this.handleSubmit = this.handleSubmit.bind(this)
}
componentDidMount() {
try {
this.props.fetchInitialOrders()
} catch (error) {
console.error(error)
}
}
clickHandlerOne() {
let hidden = this.state.showForm
this.setState({
showForm: !hidden
})
}
handleChange(event) {
//console.log('event.target', event.target)
this.setState({
[event.target.name]: event.target.value
})
}
async handleSubmit(orderId) {
event.preventDefault()
const updatedOrder = {
id: orderId,
status: this.state.stat
}
// console.log('UPDATE ORDER', updatedOrder)
await this.props.updateOrderThunk(updatedOrder)
this.props.fetchInitialOrders()
}
render() {
const orders = this.props.orders
// console.log('PROPS', this.props)
console.log('ORDERS', this.props.orders)
// const beers = orders.beers || []
return (
<div>
{/* <div className="options">
<select onChange={this.handleChange}>
<option value="">Sort By...</option>
<option value="priceHighToLow">Price (high to low)</option>
<option value="priceLowToHigh">Price (low to high)</option>
<option value="name">Name</option>
</select>
<BeerFilter />
</div> */}
<div className="flex-cards">
{orders.map(order => (
<Card style={{width: '18rem'}} key={order.id}>
<Card.Body>
<Card.Title>Order Id: {order.id}</Card.Title>
<Card.Text>
<div>
<ul>
<li>
<div className="highlight">
<img src={order.user.imageUrl} />
</div>
<div className="details">
<p>User: {order.user.username}</p>
<p>Order Status: {order.status}</p>
<p>
Order Date:{' '}
{new Intl.DateTimeFormat('en-GB', {
month: 'short',
day: '2-digit',
year: 'numeric'
}).format(new Date(order.createdAt))}
</p>
<div>
{' '}
Total Quantity:
{order.beers.reduce(function(totalQuantity, beer) {
return (
beer['beer-orders'].quantity + totalQuantity
)
}, 0)}
</div>
{/* */}
<div>
{' '}
Total Price:
{toDollars(
order.beers.reduce(function(totalPrice, beer) {
return (
beer.price * beer['beer-orders'].quantity +
totalPrice
)
}, 0)
)}
</div>
{/* */}
<Button
id={`status${order.id}`}
onClick={() => {
this.clickHandlerOne()
}}
variant="outline-primary"
>
Update Status Toggle
</Button>
<UncontrolledCollapse toggler={`#status${order.id}`}>
<form onSubmit={() => this.handleSubmit(order.id)}>
<div>
<span>
<select
name="stat"
value={
typeof order.status === 'string'
? this.state.stat
: order.status
}
onChange={this.handleChange}
>
<option value="">
select order status
</option>
<option value="open">open</option>
<option value="processing">
processing
</option>
<option value="cancelled">cancelled</option>
</select>
</span>
<div>
{/* */}
<button type="submit">Edit</button>
</div>
</div>
{/* delete thunk
<span>
<p>
<button type="button">Delete</button>
</p>
</span>
*/}
</form>
</UncontrolledCollapse>
<div> -----------------------------------------</div>
<Button
variant="info"
id={`order${order.id}`}
style={{marginBottom: '1rem'}}
>
Order Details Toggle
</Button>
<UncontrolledCollapse toggler={`#order${order.id}`}>
<Card>
<CardBody>
<span>
<div>
{order.beers.length === 0
? `${order.user.username} has no orders!`
: order.beers.map(beer => (
<div key={beer.id}>
<p> Beer Name: {beer.name} </p>
<img src={beer.imageUrl} />
<p>
{' '}
Beer Description:{' '}
{beer.description}{' '}
</p>
<p> Beer IBU: {beer.ibu} </p>
<p>
{' '}
Beer Price:{' '}
{toDollars(beer.price)}{' '}
</p>
<div>
{' '}
--------------------------------
</div>
</div>
))}
</div>
</span>
</CardBody>
</Card>
</UncontrolledCollapse>
</div>
</li>
</ul>
</div>
</Card.Text>
</Card.Body>
</Card>
))}
</div>
</div>
)
}
}
const mapStateToProps = state => {
return {
orders: state.allOrders
}
}
const mapDispatchToProps = dispatch => {
return {
loadSingleOrder: id => dispatch(fetchSingleOrder(id)),
updateOrderThunk: updatedOrder => dispatch(updateOrderThunk(updatedOrder)),
//getSortedBeers: (sortBy, beers) => dispatch(sortBeers(sortBy, beers)),
fetchInitialOrders: () => dispatch(getOrders())
}
}
export default connect(mapStateToProps, mapDispatchToProps)(AllOrders)
如何修复我的代码,以便我可以对其进行适当地渲染?
答案 0 :(得分:0)
我认为问题出在这里
<Button
variant="primary"
id="toggler"
style={{marginBottom: '1rem'}}
>
Order Details Toggle
</Button>
<UncontrolledCollapse toggler="#toggler">
ID属性必须是唯一的(https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes/id)
修正:
<Button
variant="primary"
id={order.id}
style={{marginBottom: '1rem'}}
>
Order Details Toggle
</Button>
<UncontrolledCollapse toggler={`#${order.id}`}>