React Quiz Form Generator
Build interactive quizzes and assessments
Form Preview
React Code
import React, { useState } from 'react';
import './styles.css'; // You can create a separate CSS file or use styled-components
const QuizForm = () => {
// State for form data
const [formData, setFormData] = useState({
name: '',
email: '',
question1: '',
question2: '',
question3: '',
});
// Handle input changes
const handleChange = (e) => {
const { name, value, type, checked } = e.target;
if (type === 'checkbox') {
// Handle checkboxes differently based on multiple or single
if (name === 'consent' || name === 'terms' || name === 'remember') {
setFormData({
...formData,
[name]: checked ? 'Yes' : ''
});
} else {
// For multiple checkbox options
if (checked) {
setFormData({
...formData,
[name]: [...formData[name], value]
});
} else {
setFormData({
...formData,
[name]: formData[name].filter(item => item !== value)
});
}
}
} else {
setFormData({
...formData,
[name]: value
});
}
};
// Handle form submission
const handleSubmit = (e) => {
e.preventDefault();
console.log('Form submitted with data:', formData);
// You would typically send this data to an API here
alert('Form submitted successfully!');
};
return (
<div className="form-container">
<form onSubmit={handleSubmit}>
<div className="form-group">
<label htmlFor="name" className="required">Your Name</label>
<input
type="text"
id="name"
name="name"
value={formData.name}
onChange={handleChange}
required
/>
</div>
<div className="form-group">
<label htmlFor="email" className="required">Email Address</label>
<input
type="email"
id="email"
name="email"
value={formData.email}
onChange={handleChange}
required
/>
</div>
<div className="form-group">
<label htmlFor="question1" className="required">Question 1: What is the capital of France?</label>
<div className="radio-group">
<div className="radio-item">
<input
type="radio"
id="question1-0"
name="question1"
value="London"
checked={formData.question1 === 'London'}
onChange={handleChange}
required
/>
<label htmlFor="question1-0">London</label>
</div>
<div className="radio-item">
<input
type="radio"
id="question1-1"
name="question1"
value="Berlin"
checked={formData.question1 === 'Berlin'}
onChange={handleChange}
/>
<label htmlFor="question1-1">Berlin</label>
</div>
<div className="radio-item">
<input
type="radio"
id="question1-2"
name="question1"
value="Paris"
checked={formData.question1 === 'Paris'}
onChange={handleChange}
/>
<label htmlFor="question1-2">Paris</label>
</div>
<div className="radio-item">
<input
type="radio"
id="question1-3"
name="question1"
value="Madrid"
checked={formData.question1 === 'Madrid'}
onChange={handleChange}
/>
<label htmlFor="question1-3">Madrid</label>
</div>
</div>
</div>
<div className="form-group">
<label htmlFor="question2" className="required">Question 2: Which planet is closest to the sun?</label>
<div className="radio-group">
<div className="radio-item">
<input
type="radio"
id="question2-0"
name="question2"
value="Earth"
checked={formData.question2 === 'Earth'}
onChange={handleChange}
required
/>
<label htmlFor="question2-0">Earth</label>
</div>
<div className="radio-item">
<input
type="radio"
id="question2-1"
name="question2"
value="Venus"
checked={formData.question2 === 'Venus'}
onChange={handleChange}
/>
<label htmlFor="question2-1">Venus</label>
</div>
<div className="radio-item">
<input
type="radio"
id="question2-2"
name="question2"
value="Mercury"
checked={formData.question2 === 'Mercury'}
onChange={handleChange}
/>
<label htmlFor="question2-2">Mercury</label>
</div>
<div className="radio-item">
<input
type="radio"
id="question2-3"
name="question2"
value="Mars"
checked={formData.question2 === 'Mars'}
onChange={handleChange}
/>
<label htmlFor="question2-3">Mars</label>
</div>
</div>
</div>
<div className="form-group">
<label htmlFor="question3" className="required">Question 3: Who painted the Mona Lisa?</label>
<div className="radio-group">
<div className="radio-item">
<input
type="radio"
id="question3-0"
name="question3"
value="Van Gogh"
checked={formData.question3 === 'Van Gogh'}
onChange={handleChange}
required
/>
<label htmlFor="question3-0">Van Gogh</label>
</div>
<div className="radio-item">
<input
type="radio"
id="question3-1"
name="question3"
value="Picasso"
checked={formData.question3 === 'Picasso'}
onChange={handleChange}
/>
<label htmlFor="question3-1">Picasso</label>
</div>
<div className="radio-item">
<input
type="radio"
id="question3-2"
name="question3"
value="Da Vinci"
checked={formData.question3 === 'Da Vinci'}
onChange={handleChange}
/>
<label htmlFor="question3-2">Da Vinci</label>
</div>
<div className="radio-item">
<input
type="radio"
id="question3-3"
name="question3"
value="Michelangelo"
checked={formData.question3 === 'Michelangelo'}
onChange={handleChange}
/>
<label htmlFor="question3-3">Michelangelo</label>
</div>
</div>
</div>
<div className="form-group">
<button type="submit">Submit</button>
</div>
</form>
</div>
);
};
export default QuizForm;
/* CSS Styles to add to styles.css */
/*
.form-container {
max-width: 600px;
margin: 0 auto;
background: #f9f9f9;
padding: 20px;
border-radius: 8px;
box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
}
.form-group {
margin-bottom: 15px;
}
label {
display: block;
margin-bottom: 5px;
font-weight: bold;
}
.required:after {
content: " *";
color: red;
}
input[type="text"],
input[type="email"],
input[type="password"],
input[type="tel"],
input[type="number"],
input[type="date"],
select,
textarea {
width: 100%;
padding: 8px;
border: 1px solid #ddd;
border-radius: 4px;
box-sizing: border-box;
font-size: 16px;
}
textarea {
height: 100px;
}
.checkbox-group, .radio-group {
margin-bottom: 10px;
}
.checkbox-item, .radio-item {
margin-bottom: 5px;
}
button {
background-color: #4CAF50;
color: white;
padding: 10px 15px;
border: none;
border-radius: 4px;
cursor: pointer;
font-size: 16px;
}
button:hover {
background-color: #45a049;
}
*/
Installation
How to setup React Quiz form
- 1
Sign up to parrotforms.com
Create your first form API endpoint then copy your endpoint.
Screenshot Placeholder - 2
Copy the example code
Use the copy button above to copy the entire code snippet.
Screenshot Placeholder - 3
Paste the code and update the endpoint
Replace the form API endpoint with the one you got in step 1.
Screenshot Placeholder - 4
Collect submissions
View and manage all form submissions in your parrotForms dashboard.
Screenshot Placeholder
Need more advanced forms?
Create a free parrotForms account to access more templates, save your forms, and collect submissions.
Create a Free Account