优雅的用户体验:微信小程序中的多步骤表单引导

news2024/9/20 22:22:42

前言

在微信小程序中,实现一个多步骤表单引导界面既可以提供清晰的任务指引,又可以增加用户体验的互动性。本文将探讨如何使用微信小程序的特性,构建一个流程引导界面,帮助用户一步步完成复杂任务。我们将从设计布局和样式开始,逐步引导用户完成表单,最终实现一个美观的用户界面。


源码如下

wxml 文件

<view class="mainBox">
    <!-- 步骤条 -->
    <view class="stepBox">
        <text class="{{currentStep>=1?'active':''}}">1</text>
        <text class="{{currentStep>=2?'active':''}}">2</text>
        <text class="{{currentStep>=3?'active':''}}">3</text>
        <text class="{{currentStep>=4?'active':''}}">4</text>
        <text class="{{currentStep>=5?'active':''}}">完成</text>
    </view>
    <!-- 内容根据当前步骤进行显示,这里可以放置相应的表单内容等 -->
    <view class="stepConBox">
        <view wx:if="{{currentStep == 1}}">内容111</view>
        <view wx:if="{{currentStep == 2}}">内容222</view>
        <view wx:if="{{currentStep == 3}}">内容333</view>
        <view wx:if="{{currentStep == 4}}">内容444</view>
        <view wx:if="{{currentStep == 5}}">完成</view>
    </view>
    <!-- 操作按钮 -->
    <view class="btnsBox">
        <button wx:if="{{currentStep > 1 && currentStep < 5}}" bindtap="prevStepOn">上一步</button>
        <button wx:if="{{currentStep < 4}}" bindtap="nextStepOn">下一步</button>
        <button wx:if="{{currentStep == 4 || currentStep == 5}}" bindtap="{{currentStep == 4 ? 'submitFormOn' : 'completeOn'}}">{{currentStep == 4 ? '提交' : '完成'}}</button>
    </view>
</view>

js 文件

Page({
    data: {
        currentStep: 1, // 初始化数据,currentStep 代表当前的步骤,初始值为 1
    },
    // 上一步按钮点击事件处理函数
    prevStepOn() {
        // 检查当前步骤是否大于 1,以确保不会回到步骤 0
        if (this.data.currentStep > 1) {
            // 更新数据,将当前步骤减 1
            this.setData({
                currentStep: this.data.currentStep - 1
            });
        }
    },
    // 下一步按钮点击事件处理函数
    nextStepOn() {
        // 检查当前步骤是否小于 4,以确保不会超过最大步骤数
        if (this.data.currentStep < 4) {
            // 更新数据,将当前步骤加 1
            this.setData({
                currentStep: this.data.currentStep + 1
            });
        }
    },
    // 提交按钮点击事件处理函数
    submitFormOn() {
        // 在这里执行提交操作,可以调用相应的接口或处理表单数据
        // 显示提交成功的提示
        wx.showToast({
            title: '提交成功',
            icon: 'none',
            duration: 2000
        });
        // 设置当前步骤为 5,表示已完成
        this.setData({
            currentStep: 5
        });
    },
    // 完成按钮点击事件处理函数
    completeOn() {
        this.setData({
            currentStep: 1
        });
    },
});

wxss 文件

.mainBox {
    padding: 20rpx;
}

/* 定义步骤指示器的样式 */
.stepBox {
    font-size: 28rpx;
    font-weight: bold;
    display: flex;
    justify-content: space-around;
}

/* 定义步骤指示器中的文本样式 */
.stepBox text {
    background: #CEDDF5;
    width: 116rpx;
    height: 60rpx;
    text-align: center;
    line-height: 60rpx;
    color: #fff;
    border-radius: 8rpx;
}

/* 定义步骤指示器中处于活动状态的文本样式 */
.stepBox text.active {
    background: #477BF7;
}

/* 设置步骤内容容器的内边距 */
.stepConBox {
    padding: 20rpx;
}

/* 定义按钮容器的样式 */
.btnsBox {
    display: flex;
    justify-content: space-between;
    margin-top: 20px;
}

/* 定义按钮样式 */
.btnsBox button {
    width: 50%;
    font-size: 30rpx;
    font-weight: bold;
    background: linear-gradient(151deg, #2F7EFC 0%, #7BADFC 100%);
    color: #fff;
    border: none;
    border-radius: 50rpx;
}

/* 定义除第一个按钮外的按钮样式,设置左外边距 */
.btnsBox button:nth-child(n+2) {
    margin-left: 20rpx;
}

实现思路

以上代码就实现了基于小程序框架的多步骤表单引导界面,其中包含了步骤条、不同步骤下的内容展示和操作按钮。首先,让我们从代码的结构开始解析:

HTML 结构:

mainBox 是整个页面的主容器,包含了步骤条、内容展示区和操作按钮区;
stepBox 是步骤条容器,用于显示当前步骤的进度,通过 class 的条件渲染来表示当前步骤是否激活;
stepConBox 是内容展示区容器,通过 wx:if 条件渲染来显示与当前步骤相关的内容;
btnsBox 是操作按钮区容器,根据当前步骤的不同,展示上一步、下一步、提交和完成按钮。

JavaScript 逻辑:

Page 函数用于定义页面的初始数据,其中 currentStep 初始化为 1,表示当前所在的步骤;
prevStepOn 函数处理上一步按钮的点击事件,确保不会回到步骤 0,通过修改 currentStep 更新界面;
nextStepOn 函数处理下一步按钮的点击事件,确保不会超过最大步骤数,同样通过修改 currentStep 更新界面;
submitFormOn 函数处理提交按钮的点击事件,执行提交操作,例如调用接口或处理表单数据,同时显示提交成功的提示,将 currentStep 设置为 5,表示已完成;
completeOn 函数处理完成按钮的点击事件,将 currentStep 重置为 1,重新开始流程。

  • 初始化

    在页面加载时,初始化 currentStep1,显示第一个步骤的内容和相应的步骤条。

  • 上一步和下一步

    当用户点击上一步按钮时,检查当前步骤是否大于 1,如果是,就减小 currentStep,并根据新的 currentStep 来渲染相应的内容和步骤条。
    当用户点击下一步按钮时,检查当前步骤是否小于 4,如果是,就增加 currentStep,并根据新的 currentStep 来渲染相应的内容和步骤条。

  • 提交表单

    当用户点击提交按钮时,执行提交操作,可以调用后端接口或处理表单数据,然后显示提交成功的提示信息。
    currentStep 设置为 5,表示已完成所有步骤。

  • 完成流程

    用户完成所有步骤后,可以点击完成按钮,将 currentStep 重置为 1,重新开始整个流程。


实现效果

在这里插入图片描述


相关推荐

⭐ 让你的物流信息一目了然:微信小程序实现进度展示

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1122903.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

彻底弄懂base64的编码与解码原理

背景 base64的编码原理网上讲解较多&#xff0c;但解码原理讲解较少&#xff0c;并且没有对其中的内部实现原理进行剖析。想要彻底了解base64的编码与解码原理&#xff0c;请耐心看完此文&#xff0c;你一定会有所收获。 涉及算法与逻辑运算概念 在探究base64编码原理和解码…

macrodata数据集在Python统计建模和计量经济学中的应用

目录 一、数据介绍二、应用三、statsmodels 统计模块四、使用 statsmodels 统计模块分析 macrodata.csv 数据集参考 一、数据介绍 macrodata.csv是一个示例数据集&#xff0c;通常用于统计分析和计量经济学中的教育和训练目的。这个数据集通常包括以下列&#xff1a; year&am…

17.3 实现无管道反向CMD

WSASocket无管道反向CMD&#xff0c;与无管道正向CMD相反&#xff0c;这种方式是在远程主机上创建一个TCP套接字&#xff0c;并绑定到一个本地地址和端口上。然后在本地主机上&#xff0c;使用WSASocket函数连接到远程主机的套接字&#xff0c;并将标准输入、输出和错误输出重定…

深入 Meven:构建杰出的软件项目的完美工具

掌握 Meven&#xff1a;构建更强大、更智能的应用程序的秘诀 Maven1.1 初识Maven1.1.1 什么是Maven1.1.2 Maven的作用 02. Maven概述2.1 Maven介绍2.2 Maven模型2.3 Maven仓库2.4 Maven安装2.4.1 下载2.4.2 安装步骤 03. IDEA集成Maven3.1 配置Maven环境3.1.1 当前工程设置3.1.…

JDBC相关记录

JDBC&#xff1a;Java DadaBase Connectivity 即Java语言连接数据库。 本质&#xff1a;JDBC是SUN公司制定的一套接口&#xff08;interface&#xff09;。 作用&#xff1a;不同的数据库有自己独特设计原理&#xff0c;JDBC的可以让Java程序员关注业务本身&#xff0c;而不需要…

Programming abstractions in C阅读笔记:p181-p183

《Programming Abstractions In C》学习第61天&#xff0c;p181-p183总结。 一、技术总结 1.linear search algorithm 2.lexicographic order(字典顺序) 3.binary search algorithm(二分查找算法) /** 1.二分查找也应用了递归的思想。* 2.这里的代码只是demo*/ #include &…

17.2 实现无管道正向CMD

WSASocket 无管道正向CMD&#xff0c;使用WSASocket函数创建一个TCP套接字&#xff0c;并绑定到一个本地地址和端口上。然后使用CreateProcess函数创建一个新的CMD进程&#xff0c;并将标准输入、输出和错误输出重定向到套接字的句柄上。这样&#xff0c;客户端可以通过网络连接…

应用开发平台集成工作流系列之16——办理意见设计与实现

背景 流程任务流转过程中&#xff0c;各环节的处理&#xff0c;会填写处理意见。 Camunda自带了相关的功能&#xff0c;但功能过于简陋&#xff0c;问题较多&#xff0c;今天来说说这一块。 自带功能的问题 如使用Camunda官方自身的办理意见相关功能&#xff0c;会遇到两个问…

【C++进阶(九)】C++多态深度剖析

&#x1f493;博主CSDN主页:杭电码农-NEO&#x1f493;   ⏩专栏分类:C从入门到精通⏪   &#x1f69a;代码仓库:NEO的学习日记&#x1f69a;   &#x1f339;关注我&#x1faf5;带你学习C   &#x1f51d;&#x1f51d; 多态 1. 前言2. 多态的概念以及定义3. 多态的实…

Generator异步解决方案详解

一&#xff1a;三种常见的异步解决方案 Promise&#xff1a;链式编程async&#xff1a;使用 async 去修饰函数&#xff0c;然后使用 await 去等待成功Generator&#xff1a;使用 * 修饰函数&#xff0c;然后使用 yield 去等待成功 通俗来讲&#xff0c;Generator 类似于 Promi…

【Java 进阶篇】Java XML组成部分:理解XML的结构

XML&#xff08;可扩展标记语言&#xff09;是一种常用于存储和交换数据的标记语言。了解XML的结构和组成部分对于有效处理XML数据至关重要。在本篇博客中&#xff0c;我们将深入探讨XML的组成部分&#xff0c;以及如何使用Java来处理和操作XML数据。 什么是XML&#xff1f; …

预测宝可梦武力值、分类宝可梦

regression case 股票预测 无人车看到的各种sensor 影像镜头看到马路上的东西作为输入&#xff0c;输出就是方向盘角度等等的操纵策略 scalar 标量 这个是热力图&#xff0c;相当于你的XYZ但是Z用颜色表示了 closed-form solution 闭合解 learning rate事先定好的数值 在lin…

Vue中的v-for指令是用来做什么的?

在Vue中,v-for是一个用于渲染列表或集合的指令。它通过迭代数据源中的每个元素,生成对应的DOM节点或组件实例,并将它们渲染到页面上。 v-for指令的基本语法如下: <template><div><ul><li v-for="item in items" :key="item.id"…

基于ssm流浪动物领养救助系统

摘要 基于SSM&#xff08;Spring SpringMVC MyBatis&#xff09;的流浪动物领养救助系统是一个用于管理和帮助流浪动物领养、救助的信息化平台。该系统旨在提供一种便捷、高效的方式&#xff0c;以协调和改善流浪动物的生活&#xff0c;并促进社会各界的参与和支持。以下是该…

重生奇迹mu“荣誉之城”勇者大陆

曾经&#xff0c;不少重生奇迹mu玩家讨论最经典的新人出生地&#xff0c;有的说是仙踪林&#xff0c;有的则是说勇者大陆&#xff0c;最后在重生奇迹mu网站上面&#xff0c;以投票的方式最终得出一个答案&#xff0c;那就是勇者大陆&#xff0c;游戏里面当之无愧的荣誉之城&…

c语言程序设计——题目:将一个正整数分解质因数。例如:输入90,打印出90=2*3*3*5。

题目&#xff1a;将一个正整数分解质因数。例如&#xff1a;输入90,打印出902*3*3*5。 程序分析&#xff1a;对n进行分解质因数&#xff0c;应先找到一个最小的质数k&#xff0c;然后按下述步骤完成 (1)如果这个质数恰等于&#xff08;小于的时候&#xff0c;继续执行循环&…

C#,数值计算——分类与推理Phylo_nj的计算方法与源程序

1 文本格式 using System; using System.Collections.Generic; namespace Legalsoft.Truffer { public class Phylo_nj : Phylagglom { public double[] u; public override void premin(double[,] d, int[] nextp) { i…

spring6-国际化:i18n | 数据校验:Validation

文章目录 1、国际化&#xff1a;i18n1.1、i18n概述1.2、Java国际化1.3、Spring6国际化1.3.1、MessageSource接口1.3.2、使用Spring6国际化 2、数据校验&#xff1a;Validation2.1、Spring Validation概述2.2、实验一&#xff1a;通过Validator接口实现2.3、实验二&#xff1a;B…

AI只需26秒,就可以设计一款会走路的机器人

由西北大学、麻省理工学院和佛蒙特大学组成的一支科研团队首次开发出一种可以完全自行设计机器人的 AI 算法。 这一 AI 算法不仅运行速度快&#xff0c;还可在个人计算机上运行&#xff0c;并从头开始设计全新的结构。只需告诉AI“我们想要一个可穿越陆地的机器人”&#xff0c…

【Java 进阶篇】Java XML快速入门:理解、解析和生成XML

XML&#xff08;可扩展标记语言&#xff09;是一种常用于存储和交换数据的标记语言&#xff0c;而Java是一种强大的编程语言&#xff0c;它具有处理XML的能力。在本篇博客中&#xff0c;我们将探讨XML的基础知识&#xff0c;学习如何在Java中解析和生成XML文档&#xff0c;以及…