基于jquery实现一个滚动的分步注册向导-附源码


Posted in Javascript onAugust 26, 2015

先给大家展示效果图,需要的朋友可以下载源码哦~

基于jquery实现一个滚动的分步注册向导-附源码

查看演示        下载源码

HTML

首先要载入jquery库和滚动插件scrollable.js

<script type="text/javascript" src="jquery.js"></script> 
<script type="text/javascript" src="scrollable.js"></script>

接着构造html主体结构。

<form action="#" method="post"> 
 <div id="wizard"> 
 <ul id="status"> 
 <li class="active"><strong>1.</strong>创建账户</li> 
 <li><strong>2.</strong>填写联系信息</li> 
 <li><strong>3.</strong>完成</li> 
 </ul> 
 
 <div class="items"> 
 <div class="page"> 
  -----任意html内容----- 
  <div class="btn_nav"> 
  <input type="button" class="next right" value="下一步»" /> 
  </div> 
 </div> 
 <div class="page"> 
  -----任意html内容----- 
  <div class="btn_nav"> 
  <input type="button" class="prev" style="float:left" value="«上一步" /> 
  <input type="button" class="next right" value="下一步»" /> 
  </div> 
 </div> 
 <div class="page"> 
  -----任意html内容----- 
  <div class="btn_nav"> 
  <input type="button" class="prev" style="float:left" value="«上一步" /> 
  <input type="button" class="next right" id="sub" value="确定" /> 
  </div> 
 </div> 
 </div> 
 </div> 
</form>

以上是一个注册表单,注意在三个.page里可以填写任何你想要的html表单内容。限于篇幅本文没有列出表单具体内容。

CSS

#wizard {border:5px solid #789;font-size:12px;height:450px;margin:20px auto; 
width:570px;overflow:hidden;position:relative;} 
#wizard .items{width:20000px; clear:both; position:absolute;} 
#wizard .right{float:right;} 
#wizard #status{height:35px;background:#123;padding-left:25px !important;} 
#status li{float:left;color:#fff;padding:10px 30px;} 
#status li.active{background-color:#369;font-weight:normal;} 
.input{width:240px; height:18px; margin:10px auto; line-height:20px; 
border:1px solid #d3d3d3; padding:2px} 
.page{padding:20px 30px;width:500px;float:left;} 
.page h3{height:42px; font-size:16px; border-bottom:1px dotted #ccc; margin-bottom:20px; 
 padding-bottom:5px} 
.page h3 em{font-size:12px; font-weight:500; font-style:normal} 
.page p{line-height:24px;} 
.page p label{font-size:14px; display:block;} 
.btn_nav{height:36px; line-height:36px; margin:20px auto;} 
.prev,.next{width:100px; height:32px; line-height:32px; background:url(btn_bg.gif) 
repeat-x bottom; border:1px solid #d3d3d3; cursor:pointer}

您可以根据实际应用环境修改css,来体现不同的外观。

jQuery

毋庸置疑,和其他插件一样,直接调用方法。

$(function(){ 
 $("#wizard").scrollable(); 
});

就是这么简单,现在可以通过单击下一步切换步骤了,但有问题是导航的步骤标题tab样式没有同时切换,点击下一步时应该验证当前表单输入的合法性。值得庆幸的是,两个方法使得问题变得很简单了。

onSeek:function();当滚动当前page后发生的事情,本例中我们要切换tab样式。
onBeforeSeek:function();滚动之前发生的事情,本例中我们要验证表单。

请看代码:

$(function(){ 
 $("#wizard").scrollable({ 
 onSeek: function(event,i){ //切换tab样式 
  $("#status li").removeClass("active").eq(i).addClass("active"); 
 }, 
 onBeforeSeek:function(event,i){ //验证表单 
  if(i==1){ 
  var user = $("#user").val(); 
  if(user==""){ 
   alert("请输入用户名!"); 
   return false; 
  } 
  var pass = $("#pass").val(); 
  var pass1 = $("#pass1").val(); 
  if(pass==""){ 
   alert("请输入密码!"); 
   return false; 
  } 
  if(pass1 != pass){ 
   alert("两次密码不一致!"); 
   return false; 
  } 
  } 
 } 
 }); 
});

最后,要提交表单,获取表单的值,你可以在最后一步“确定”按钮上绑定submit()方法,通过action提交表单。本文为了演示,采用以下方法获取输入的内容:

$("#sub").click(function(){ 
 var data = $("form").serialize(); 
 alert(data); 
});
Javascript 相关文章推荐
De facto standard 世界上不可思议的事实标准
Aug 29 Javascript
jquery的ajax异步请求接收返回json数据实例
Jun 16 Javascript
jquery插件autocomplete用法示例
Jul 01 Javascript
JSON对象 详解及实例代码
Oct 18 Javascript
jQuery Validate验证框架详解(推荐)
Dec 17 Javascript
vue2.0实战之使用vue-cli搭建项目(2)
Mar 27 Javascript
Javascript实现的StopWatch功能示例
Jun 13 Javascript
详解A标签中href=&quot;&quot;的几种用法
Aug 20 Javascript
vue2.0项目集成Cesium的实现方法
Jul 30 Javascript
layui中select,radio设置不生效的解决方法
Sep 05 Javascript
layer.prompt输入层的例子
Sep 24 Javascript
js 实现watch监听数据变化的代码
Oct 13 Javascript
jQuery带时间的日期控件代码分享
Aug 26 #Javascript
js仿苹果iwatch外观的计时器代码分享
Aug 26 #Javascript
jQuery下拉友情链接美化效果代码分享
Aug 26 #Javascript
jQuery ui实现动感的圆角渐变网站导航菜单效果代码
Aug 26 #Javascript
jquery实现平滑的二级下拉菜单效果
Aug 26 #Javascript
纯javascript实现分页(两种方法)
Aug 26 #Javascript
jquery实现LED广告牌旋转系统图片切换效果代码分享
Aug 26 #Javascript
You might like
攻克CakePHP系列一 连接MySQL数据库
2008/10/22 PHP
比较全面的PHP数组的使用方法小结
2010/09/23 PHP
解析PHP中一些可能会被忽略的问题
2013/06/21 PHP
php以post形式发送xml的方法
2014/11/04 PHP
PHP的引用详解
2015/02/22 PHP
为超链接加上disabled后的故事
2010/12/10 Javascript
网页右键ie不支持event.preventDefault和event.returnValue (需要加window)
2013/02/22 Javascript
jQuery删除节点的三个方法即remove()detach()和empty()
2013/12/27 Javascript
jQuery的css()方法用法实例
2014/12/24 Javascript
js 获取元素在页面上的偏移量的方法汇总
2015/04/13 Javascript
js跨域请求的5中解决方式
2015/07/02 Javascript
JavaScript+html5 canvas制作的百花齐放效果完整实例
2016/01/26 Javascript
整理JavaScript对DOM中各种类型的元素的常用操作
2016/05/05 Javascript
浅谈jquery采用attr修改form表单enctype不起作用的问题
2016/11/25 Javascript
原生JS轮播图插件
2017/02/09 Javascript
Boostrap栅格系统与自己额外定义的媒体查询的冲突问题
2017/02/19 Javascript
JS实现点击Radio动态更新table数据
2017/07/18 Javascript
input type=file 选择图片并且实现预览效果的实例
2017/10/26 Javascript
layui固定下拉框的显示条数(有滚动条)的方法
2019/09/10 Javascript
微信小程序文章列表功能完整实例
2020/06/03 Javascript
python网络编程学习笔记(三):socket网络服务器
2014/06/09 Python
Python多线程编程(六):可重入锁RLock
2015/04/05 Python
python+PyQT实现系统桌面时钟
2020/06/16 Python
简单了解python关系(比较)运算符
2019/07/08 Python
django 通过url实现简单的权限控制的例子
2019/08/16 Python
Python lambda表达式原理及用法解析
2020/08/18 Python
RealTek面试题
2016/06/28 面试题
金融专业应届生求职信
2013/11/02 职场文书
青年文明号复核材料
2014/02/11 职场文书
本科毕业生求职自荐信
2014/04/09 职场文书
小学生民族团结演讲稿
2014/08/27 职场文书
优秀党员学习焦裕禄精神思想汇报范文
2014/09/10 职场文书
辞职信格式模板
2015/02/27 职场文书
2015年维修电工工作总结
2015/04/25 职场文书
班级班风口号大全
2015/12/25 职场文书
go web 预防跨站脚本的实现方式
2021/06/11 Golang