我有一个表,在其中映射了一些数据,在+
按钮上,我想添加新表行并使用react hook为该表行设置新的defaultState
import React, { useState, useEffect } from 'react'
import { useMutation, useQuery } from '@apollo/react-hooks'
import { Link, useParams } from 'react-router-dom'
import './style.css'
import {
GET_SURVEY,
CREATE_SURVEY,
} from './queries'
import { pushError } from '../../modules/error'
export default function SurveyDetails() {
const params = useParams()
const { data } = useQuery(GET_SURVEY, { variables: { id: params.surveyId } })
const [survey, setSurvey] = useState({})
useEffect(() => {
async function loadSurvey() {
if (data && data.me.survey) {
await setSurvey(data.me.survey)
}
}
loadSurvey()
}, [data])
const HomePage = () => (
<Link to="/home">Home</Link>
)
const SurveyPage = () => (
<Link to="/survey">Survey</Link>
)
const hadnleAddRow = () => {
console.log('?????')
const questionId = (survey.questions || []).map((t) => t.id)
const newState = {
id: params.surveyId,
questions: {
id: questionId,
questionText: '',
type: '',
options: [],
}
}
// console.log(setSurvey((preSurvey) => [...preSurvey, {}]))
setSurvey((preSurvey) => [...preSurvey, newState])
}
return (
<div>
<div style={{ display: 'flex', justifyContent: 'space-between' }}>
<h2>Survey Details</h2>
<div style={{ display: 'flex', justifyContent: 'flex-end', alignItems: 'center', flex: '1' }}>
<span style={{ paddingRight: '25px' }}><SurveyPage /></span>
<span><HomePage /></span>
</div>
</div>
<table>
<tr>
<th>Question Text</th>
<th>Type</th>
<th>Options</th>
<th>Status</th>
<th>Edit</th>
<th><button type="submit" onClick={hadnleAddRow}>+</button></th>
<th>Remove</th>
</tr>
{(survey.questions || []).map((q) => (
<tr key={q.id}>
<td>{ q.questionText }</td>
<td>{ q.type }</td>
<td>
{ q.options.join(', ')}
{' '}
</td>
<td>{ survey.status }</td>
<td><button type="submit" onClick={openModal}>Edit</button></td>
<td />
<td><button type="submit">-</button></td>
</tr>
))}
</table>
</div>
)
}
现在我面临的错误是这个
TypeError: object is not iterable (cannot read property Symbol(Symbol.iterator))
81 | }
82 | }
83 | // console.log(setSurvey((preSurvey) => [...preSurvey, {}]))
> 84 | setSurvey((preSurvey) => [...preSurvey, newState])
| ^ 85 | }
86 |
87 | return (
有人可以告诉我这是怎么回事,谢谢。
答案 0 :(得分:1)
调查是一个具有数组问题的对象(我对吗?)
您将使用 setSurvey 返回数组。
setSurvey((preSurvey) => {questions:[...preSurvey.questions, newState]})