1. ホーム
  2. javascript

[解決済み] React Hooks でオブジェクトの配列の `onChange` 状態を更新するには?

2023-08-27 23:57:33

質問

を使用して保存されたデータを取得しました。 useState で保存されているデータをオブジェクトの配列で取得し、そのデータをフォームのフィールドに出力しています。そして今、私は入力中にフィールド(状態)を更新することができるようにしたい。

配列のプロパティの状態を更新する例は見たことがありますが、オブジェクトの配列の状態を更新する例は見たことがないので、どうすればいいのかわかりません。コールバック関数に渡されるオブジェクトのインデックスはあるのですが、それを使って状態を更新する方法が分かりませんでした。

// sample data structure
const datas = [
  {
    id: 1,
    name: 'john',
    gender: 'm'
  }
  {
    id: 2,
    name: 'mary',
    gender: 'f'
  }
]

const [datas, setDatas] = useState([]);

const updateFieldChanged = index => e => {
  console.log('index: ' + index);
  console.log('property name: '+ e.target.name);

  setData() // ??
}

return (
  <React.Fragment>
    {datas.map((data, index) => {
      <li key={data.name}>
        <input type="text" name="name" value={data.name} onChange={updateFieldChanged(index)} />
      </li>
    })}
  </React.Fragment>
)

どのように解決するのですか?

ここでは、その方法を説明します。

// sample data structure
/* const data = [
  {
    id:   1,
    name: 'john',
    gender: 'm'
  }
  {
    id:   2,
    name: 'mary',
    gender: 'f'
  }
] */ // make sure to set the default value in the useState call (I already fixed it)

const [data, setData] = useState([
  {
    id:   1,
    name: 'john',
    gender: 'm'
  }
  {
    id:   2,
    name: 'mary',
    gender: 'f'
  }
]);

const updateFieldChanged = index => e => {
  console.log('index: ' + index);
  console.log('property name: '+ e.target.name);
  let newArr = [...data]; // copying the old datas array
  newArr[index] = e.target.value; // replace e.target.value with whatever you want to change it to

  setData(newArr);
}

return (
  <React.Fragment>
    {data.map((datum, index) => {
      <li key={datum.name}>
        <input type="text" name="name" value={datum.name} onChange={updateFieldChanged(index)}  />
      </li>
    })}
  </React.Fragment>
)