Vue.js Survey Form Generator
Create surveys with multiple question types
Form Preview
Vue.js Code
<template>
<div class="form-container">
<form @submit.prevent="handleSubmit">
<div class="form-group">
<label for="name" class="required">Your Name</label>
<input
type="text"
id="name"
v-model="formData.name"
required
/>
</div>
<div class="form-group">
<label for="email" class="required">Email Address</label>
<input
type="email"
id="email"
v-model="formData.email"
required
/>
</div>
<div class="form-group">
<label for="age" class="required">Age Group</label>
<div class="radio-group">
<div class="radio-item">
<input
type="radio"
id="age-0"
v-model="formData.age"
value="18-24"
required
/>
<label for="age-0">18-24</label>
</div>
<div class="radio-item">
<input
type="radio"
id="age-1"
v-model="formData.age"
value="25-34"
/>
<label for="age-1">25-34</label>
</div>
<div class="radio-item">
<input
type="radio"
id="age-2"
v-model="formData.age"
value="35-44"
/>
<label for="age-2">35-44</label>
</div>
<div class="radio-item">
<input
type="radio"
id="age-3"
v-model="formData.age"
value="45-54"
/>
<label for="age-3">45-54</label>
</div>
<div class="radio-item">
<input
type="radio"
id="age-4"
v-model="formData.age"
value="55+"
/>
<label for="age-4">55+</label>
</div>
</div>
</div>
<div class="form-group">
<label for="interests">Your Interests</label>
<div class="checkbox-group">
<div class="checkbox-item">
<input
type="checkbox"
id="interests-0"
v-model="formData.interests"
:value="Technology"
/>
<label for="interests-0">Technology</label>
</div>
<div class="checkbox-item">
<input
type="checkbox"
id="interests-1"
v-model="formData.interests"
:value="Sports"
/>
<label for="interests-1">Sports</label>
</div>
<div class="checkbox-item">
<input
type="checkbox"
id="interests-2"
v-model="formData.interests"
:value="Music"
/>
<label for="interests-2">Music</label>
</div>
<div class="checkbox-item">
<input
type="checkbox"
id="interests-3"
v-model="formData.interests"
:value="Art"
/>
<label for="interests-3">Art</label>
</div>
<div class="checkbox-item">
<input
type="checkbox"
id="interests-4"
v-model="formData.interests"
:value="Travel"
/>
<label for="interests-4">Travel</label>
</div>
<div class="checkbox-item">
<input
type="checkbox"
id="interests-5"
v-model="formData.interests"
:value="Food"
/>
<label for="interests-5">Food</label>
</div>
</div>
</div>
<div class="form-group">
<label for="comments">Additional Comments</label>
<textarea
id="comments"
v-model="formData.comments"
></textarea>
</div>
<div class="form-group">
<button type="submit">Submit</button>
</div>
</form>
</div>
</template>
<script>
export default {
name: 'SurveyForm',
data() {
return {
formData: {
name: '',
email: '',
age: '',
interests: [],
comments: '',
}
};
},
methods: {
handleSubmit() {
console.log('Form submitted with data:', this.formData);
// You would typically send this data to an API here
alert('Form submitted successfully!');
}
}
};
</script>
<style scoped>
.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;
}
</style>
Installation
How to setup Vue.js Survey 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