如何在componentdidmount

时间:2019-10-23 22:36:49

标签: reactjs render setstate react-component react-state

我使用在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>
    );
  }
}

非常感谢!

1 个答案:

答案 0 :(得分:2)

您的渲染似乎错误地实现了严格的不等式。您正在使用==!,但应为!==

{
  paintingPhotos !== null ? 
    paintingPhotos.map((anObjectMapped, index) => (
      <option value={anObjectMapped.title}>{anObjectMapped.title}</option>
    ) : ""
}