我使用在componentdidmount中调用的函数从后端提取数据(对象数组)。 我知道渲染发生在之前 componentdidmount。
我将初始状态设置为null,我可以看到数据确实是通过使用cosole.log()获得的,但是如何在渲染器中使用这些数据呢?
我正在尝试使用用于选择下拉菜单的对象数组,但是状态更改后似乎没有更新。
以下是一些相关代码:
class PaintingPhotoForm extends Component {
constructor(props) {
super(props);
this.state = {
apiPaintingPhotosEndpoint: `/api/paintings/photos?`,
paintingPhotos: null,
};
}
loadUniqueTitleIds = (clickedEndpoint) => {
let endpoint = this.state.apiPaintingPhotosEndpoint
if (clickedEndpoint !== undefined){
endpoint = clickedEndpoint
}
let lookupOptions = {
method: "GET",
headers: {
"Content-Type": "application/json"
}
};
const csrfToken = cookie.load("csrftoken");
if (csrfToken !== undefined) {
lookupOptions["credentials"] = "include";
lookupOptions["headers"]["X-CSRFToken"];
}
fetch(endpoint, lookupOptions)
.then(response => {
return response.json();
})
.then(responseData => {
this.setState({
paintingPhotos: responseData,
});
})
.catch(error => {
console.log("error", error);
});
}
componentDidMount() {
this.loadUniqueTitleIds()
}
render() {
const {paintingPhotos} = this.state;
console.log(paintingPhotos)
return (
<form onSubmit={this.handleSubmit} ref={(el) => this.paintingCreateForm = el}>
<div>
<label for="title">Title ID</label>
<select id="title"
name="title"
className=""
onChange={this.handleInputChange}
value={title_id}
// required="required"
>
{
paintingPhotos ==! null ?
paintingPhotos.map((anObjectMapped, index) =>
<option value={anObjectMapped.title} >{anObjectMapped.title}</option>
)
: ""
}
</select>
</div>
<button className="btn btn-primary">Save</button>
<button className={`btn btn-secondary`} onClick={this.clearForm}>
Clear
</button>
</form>
);
}
}
非常感谢!
答案 0 :(得分:2)
您的渲染似乎错误地实现了严格的不等式。您正在使用==!
,但应为!==
:
{
paintingPhotos !== null ?
paintingPhotos.map((anObjectMapped, index) => (
<option value={anObjectMapped.title}>{anObjectMapped.title}</option>
) : ""
}