data:image/s3,"s3://crabby-images/eb783/eb7836c06f693bce0956bbddc8ca57eb20516abb" alt="Chris_Laurie Chris_Laurie"
- Mark as New
- Bookmark
- Subscribe
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Jun 23, 2020 09:39 PM
Hi all - I’m new to react and web dev in general. I have created a Box with a FormField inside. It displays correctly but I cannot seem to enter any text in the input field. It is not taking any values, like it is read-only. Does anyone know what I am doing wrong? Here is my code:
<Box
padding="20px"
border="thick"
borderRadius="large"
>
<div>
<FormField
label= {formLabel}
>
<Input
placeholder = {descriptionPlaceHolder}
value = {addDescription}
onChange={e => addDescription = e.target.value}
/>
<Button
style = {{marginTop: 10}}
onClick = {() => {}}
>
Add
</Button>
</FormField>
</div>
</Box>
Solved! Go to Solution.
Accepted Solutions
data:image/s3,"s3://crabby-images/eb783/eb7836c06f693bce0956bbddc8ca57eb20516abb" alt="Chris_Laurie Chris_Laurie"
- Mark as New
- Bookmark
- Subscribe
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Jun 23, 2020 10:06 PM
Solved it - I do not yet quite understand the state and how react deals with it. You have to tajke the onChange via the state, So adding a useState and setState solved it for me:
const [descript, setdescript] = useState("");
…
onChange={e => setdescript(e.target.value)}
data:image/s3,"s3://crabby-images/addae/addae48351e2c8e059d4d74140ca3d86b5c4685d" alt="Kamille_Parks Kamille_Parks"
- Mark as New
- Bookmark
- Subscribe
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Jun 23, 2020 09:42 PM
Try taking the button out of the form field, I think form fields only support one child element (your input).
data:image/s3,"s3://crabby-images/eb783/eb7836c06f693bce0956bbddc8ca57eb20516abb" alt="Chris_Laurie Chris_Laurie"
- Mark as New
- Bookmark
- Subscribe
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Jun 23, 2020 09:47 PM
Thanks Kamille - I have tried that already and it has the same result. The field remains inactive.
data:image/s3,"s3://crabby-images/eb783/eb7836c06f693bce0956bbddc8ca57eb20516abb" alt="Chris_Laurie Chris_Laurie"
- Mark as New
- Bookmark
- Subscribe
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Jun 23, 2020 10:06 PM
Solved it - I do not yet quite understand the state and how react deals with it. You have to tajke the onChange via the state, So adding a useState and setState solved it for me:
const [descript, setdescript] = useState("");
…
onChange={e => setdescript(e.target.value)}
data:image/s3,"s3://crabby-images/65db9/65db99def1ef166fe48b74d5ed1b6cad5a7ef96b" alt="Jay_Ransijn Jay_Ransijn"
- Mark as New
- Bookmark
- Subscribe
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Jun 24, 2020 04:55 PM
In React controls such as inputs should normally be “controlled”. That means that there is always a value kept in state (through the useState
hook) that is passed to the value of the input. This model of always rendering your data in a single direction makes things easy to reason about your app once it grows. For instance you can use the value somewhere else, and it isn’t just locked in your input, for instance:
const [value, setValue] = useState('');
return (
<div>
<Input
value={value}
onChange={e => setValue(e.target.value)}
/>
<p>Here is your value always in sync: {value}</p>
</div>
):
data:image/s3,"s3://crabby-images/fd698/fd698713d0baac0a63656a05635b6caad01a7886" alt=""