所以即時嘗試使反應與ES6語法一起工作。在ES5中,我有setInitialState,沒有使用函數綁定語法的構造函數。我有一個價格列表是任意的,我希望狀態在輸入元素改變時改變。但是正確的價格必須改變。將多個參數傳遞給React中的onChange/onClick函數
我甚至不確定這是做到這一點的正確方法。有人可以告訴我最近的做法嗎?
這裏是我的代碼:
import React, {Component} from 'react'
import 'bootstrap/dist/css/bootstrap.css';
export default class PriceTable extends Component {
constructor(props, context) {
super(props, context);
this.state = {
pid: this.props.pid || "12345",
name: this.props.name || "name",
prices: this.props.prices || [
{count: 1, desc: 'one', price: 8.25},
{count: 6, desc: 'six', price: 7.60},
{count: 12, desc: 'twelve', price: 6.953}
]
};
this.setPid = this.setPid.bind(this);
this.setName = this.setName.bind(this);
this.setCount = this.setCount.bind(this, i);
this.setDesc = this.setDesc.bind(this, i);
this.setPrice = this.setPrice.bind(this, i);
this.logDebug = this.logDebug.bind(this);
}
setPid(e) {
this.setState({pid: e.target.value})
}
setName(e) {
this.setState({name: e.target.value})
}
setCount(i, e) {
var newPrices = this.state.prices
newPrices[i].count = e.target.value
this.setState({prices: newPrices})
}
setDesc(i, e) {
var newPrices = this.state.prices
newPrices[i].sec = e.target.value
this.setState({prices: newPrices})
}
setPrice(i, e) {
var newPrices = this.state.prices
newPrices[i].price = e.target.value
this.setState({prices: newPrices})
}
_renderPriceRow(price, i) {
return (
<tr key={i}>
<td >
<input type="text" className="form-control" defaultValue={price.count} onChange={this.setCount(this, i).bind(this, i)}/>
</td>
<td >
<input type="text" className="form-control" defaultValue={price.desc} onChange={this.setDesc(this, i).bind(this, i)}/>
</td>
<td >
<input type="text" className="form-control" defaultValue={price.price} onChange={this.setPrice(this, i).bind(this, i)}/>
</td>
</tr>
);
}
render() {
return (
<div className="row">
...
</div>
);
}
}
這是錯誤...
PriceTable.jsx:21 Uncaught ReferenceError: i is not defined
at new PriceTable (PriceTable.jsx:21)
這實際上與根本不綁定函數的效果相同。我得到以下錯誤:'''Uncaught TypeError:無法在_renderPriceRow中讀取未定義屬性'setCount''' –
那是因爲您沒有綁定renderPriceRow函數。檢查更新 –
您可以簡要解釋爲什麼我必須綁定該功能嗎?是因爲這個函數超出了實際類的範圍嗎?這在這裏看起來像是一個奇怪的樣板代碼。爲什麼它沒有像ES5那樣綁定? –