首页 > 解决方案 > 如何在 reactjs 和 awsamplify 中执行多个查询

问题描述

我正在尝试在 React.js 中查询超过 1 个 Dynamo 数据库。我尝试在不同的类中定义这两个组件并导入它们,但它们不起作用然后我尝试在同一个类中定义这两个组件,这给了我错误

TypeError: this.state.patients2 is undefined

这是我的组件

 state = { patients2: [] }


 async componentDidMount() {
    try {
      const apiData = await API.graphql(graphqlOperation(listPatients2))
      const patients2 = apiData.data.listPatients2.items
      this.setState({ patients2 })
    } catch (err) {
      console.log('qqqqqqqqqqqqqqqqqq ', err)
    } 
  } 

 state = { beraters: [] }
  async componentWillMount2() {
    try {
      const apiData = await API.graphql(graphqlOperation(listBeraters))
      const beraters = apiData.data.listBeraters.items
      this.setState({ beraters })
      console.log(beraters)
    } catch (err) {
      console.log('qqqqqqqqqqqqqqqqq ', err

)
    }
  } 

在这里我映射结果

<h1>Meine Daten</h1>


    {
          this.state.beraters.map((rest, i) => (
            <div style={styles.item}>
              <p style={styles.Vorname}>{rest.Vorname}</p>
              <p style={styles.Nachname}>{rest.Nachname}</p>
              <p style={styles.Strasse}>{rest.Strasse}</p>
              <p style={styles.Hausnr}>{rest.Hausnr}</p>
              <p style={styles.Ort}>{rest.Ort}</p>
              <p style={styles.Postleitzahl}>{rest.Postleitzahl}</p>
              <p style={styles.Telefonnummer}>{rest.Telefonnummer}</p>
            </div>
          ))
         }
      </div>

<div >
    {
          this.state.patients2.map((rest, i) => (
            <div style={styles.item}>
              <l style={styles.Vorname}>{rest.Vorname}</l>
              <l>  </l>
              <l style={styles.Nachname}>{rest.Nachname}</l>
            </div>
          ))


        }
      </div>

任何帮助深表感谢。谢谢!

标签: javascriptreactjsamazon-dynamodbaws-appsyncaws-amplify

解决方案


由于您正在覆盖状态值,因此您的 patients2 未定义。只需在状态中定义您的数组并同时调用您的查询。像这样的东西:

state = {
  beraters: [],
  patients2: []
}
async componentDidMount() {
    try {
      const apiDataPatients = await API.graphql(graphqlOperation(listPatients2))
      const apiDataBeraters = await API.graphql(graphqlOperation(listBeraters))
      const patients2 = apiDataPatients.data.listPatients2.items
      const beraters = apiDataBeraters.data.listBeraters.items
      this.setState({ beraters, patients2 })
    } catch (err) {
      console.log('Error:', err)
    } 
}

推荐阅读