TypeError:prevState.blockHash不可迭代

问题描述 投票:0回答:2

我正在尝试更新存储在数组中的对象。但是获取TypeError:prevState.blockHash是不可迭代的。这是我的构造函数

constructor(props) {
  super(props)

  this.state = {
    dir:"",
    account: '',
    name: [],
    fido: [{
      logIndex: [],
      transactionIndex: [],
      transactionHash: [],
      blockHash: []
    }],
    loading: true
  }

我正在以此方式设置状态-

showusingBot= () => {
  this.setState(this.initialState)
  this.state.instance.events.Artworkcreated({
    filter: { purchased: false},
    fromBlock: 0
  }).on('data', event => {
    this.setState(prevState =>({
      fido:[...prevState.fido.map({blockHash: [
        ...prevState.blockHash,   
        event.blockHash        
      ]} )]}));
    })
  }

我在控制台上的ABI响应如下。

{logIndex: 0, transactionIndex: 0, transactionHash: "0x94f6d8671988ceb8ef1da862257637a198f4afefc3aef6cf3eb992dfcafb0eb1", blockHash: "0xd26937f8535a335663c9af57335f7cc783aba0e9e376408cbb92c1b3f1b28166", blockNumber: 20, …}
logIndex: 0
transactionIndex: 0
transactionHash: "0x94f6d8671988ceb8ef1da862257637a198f4afefc3aef6cf3eb992dfcafb0eb1"
blockHash: "0xd26937f8535a335663c9af57335f7cc783aba0e9e376408cbb92c1b3f1b28166"
blockNumber: 20
address: "0x20B40e09b75a21E0B857F695dE5De92a5A5b5AD0"
type: "mined"
id: "log_0d967aac"
returnValues: Result
0: "1"
1: "bhavin"
2: "masterpiece"
3: "1000000000000000000"
4: "100"
5: "200"
6: "blah blah blah!!"
7: "0x04f78093E2a1C07BF6c4527Aaa00807d3132A1Df"
8: false
id: "1"
Artistname: "bhavin"
Artname: "masterpiece"
price: "1000000000000000000"
width: "100"
height: "200"
Description: "blah blah blah!!"
owner: "0x04f78093E2a1C07BF6c4527Aaa00807d3132A1Df"
purchased: false
__proto__: Object
event: "Artworkcreated"
signature: "0xf912339172a3b7eda9cb10ecdef181d10a74fc4411fe5d7e62f550ef3698d845"
raw: {data: "0x000000000000000000000000000000000000000000000000…16820626c6168212100000000000000000000000000000000", topics: Array(4)}
__proto__: Object

我需要将字符串推送到数组blockHash。

javascript arrays json reactjs solidity
2个回答
0
投票

blockHash不在状态中,它仅存在于state.fido的对象中。在setState中,您需要从blockHash的每个元素访问fido,而不是从整体状态访问它。


0
投票

您的整个fido地图回调不正确,应该使用一个函数,您正在传递一个对象。

this.setState(prevState =>({
  fido:[...prevState.fido.map({blockHash: [
    ...prevState.blockHash,   
    event.blockHash        
  ]} )]}));
})

正确的语法是map((current, index, originalArray) => {...})

但是我认为您不需要映射任何东西,我想您只需要散布先前状态的fido数组并添加新元素

this.setState(prevState =>({
  fido:[...prevState.fido, event.blockHash]
}));

编辑1

由于fido是静态的,正如您所说,我建议您仅将其属性存储在对象中,就像您当前将其作为数组中的元素进行处理。

this.state = {
  dir:"",
  account: '',
  name: [],
  fido: {
    logIndex: [],
    transactionIndex: [],
    transactionHash: [],
    blockHash: []
  },
  loading: true
}

现在,在更新fido状态时,以先前的状态传播[[和具有新元素的blockHash数组

this.setState(prevState =>({ fido: { ...prevState.fido, blockHash: [...prevState.fido.blockHash, event.blockHash] }, }));
© www.soinside.com 2019 - 2024. All rights reserved.