多步骤表单广泛应用于收集用户输入,例如注册、调查和客户反馈。它们将复杂的任务分解为更小的、易于管理的步骤,从而提升用户体验。
本代码示例演示了一个多步骤表单的第一个步骤,用户需要在其中选择性别。它使用 Vue.js 构建,具有以下基本功能:
import { ref } from "vue";
const gender = ref("male");
使用 ref
钩子创建 gender
响应式变量,它存储用户选择的性别。
<div class="mb-4">
<h2 class="text-gray-800 text-2xl font-bold text-center">
STEP 1 / 7
</h2>
<h2 class="text-gray-600 text-lg font-bold text-center">
Which one are you?
</h2>
</div>
这部分代码渲染步骤标题和说明,指示这是七步流程中的第一步。
<div class="flex items-center justify-center">
<div class="w-full">
<div class="flex items-center justify-center">
<div class="w-1/2 mr-2">
<button
type="button"
@click="continueToNextPage('male')"
class="..."
>
<img src="..." alt="" />
<span class="ml-4">Male</span>
</button>
</div>
<div class="w-1/2 ml-2">
<button
type="button"
@click="continueToNextPage('female')"
class="..."
>
<img src="..." alt="" />
<span class="ml-4">Female</span>
</button>
</div>
</div>
</div>
</div>
此代码创建两个选项按钮,每个按钮代表一种性别。当用户单击按钮时,它将调用 continueToNextPage
方法。
const continueToNextPage = (gender) => {
console.log("continueToNextPage", gender);
};
continueToNextPage
方法将用户选择的性别记录到 gender
响应式变量中,并打印它以供调试。在实际应用程序中,它将导航到表单的下一步骤。
开发这段代码的过程让我对多步骤表单的实现有了深入的理解。我学会了如何使用响应式变量存储用户输入,如何动态渲染步骤内容,以及如何处理用户交互。
未来,可以考虑对该表单进行以下扩展和优化: