jQuery插件实现非常实用的tab栏切换功能【案例】


Posted in jQuery onFebruary 18, 2019

本文实例讲述了jQuery插件实现tab栏切换功能。分享给大家供大家参考,具体如下:

效果:

jQuery插件实现非常实用的tab栏切换功能【案例】

核心代码:自己写了一个方法,需要用的时候直接调用就可以了.

方法如下:

(function ($) {
  //给$的fn添加方法
  $.fn.tabs=function ( options ) {
    /*   {
            tabHeads:'tab-menu>li',
            tabHeadsClass:'active',
            tabBodys:'tab-main>div',
            tabBodysClass:'selected'
          }
    */
    /**
     * @param options 对象
     * @param options.tabHeads:上面的li标签
     * @param options.tabHeadsClass:li标签需要添加的类名
     * @param options.tabBodys:下面四个内容盒子
     * @param options.tabBodysClass:下面四个内容盒子需要添加的类名
     */
      //将fn这个对象存起来,代码结束的时候让它返回
    var $bigDiv=this;
    //1.给页签们添加点击事件
    $(options.tabHeads).on('click',function ( ) {
      //2.给被点击的li标签添加类,给其它兄弟标签移除这个类
      $(this).addClass(options.tabHeadsClass).siblings().removeClass(options.tabHeadsClass);
      //3.获取当前点击的标签的索引
      var idx=$(this).index();
      //4.从下面div里面找到和idx相同的索引,给它添加类,其它兄弟页面移除这个类
      $(options.tabBodys).eq(idx).addClass(options.tabBodysClass).siblings().removeClass(options.tabBodysClass)
    })
    return $bigDiv;
  }
}(jQuery))

代码结构:

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>3water.com jQuery tab切换</title>
  <style>
    *{
      margin: 0;
      padding: 0;
    }
    ul {
      list-style: none;
    }
    .tab {
      width: 400px;
      height: 50px;
      background: #ccc;
      margin: 100px auto ;
    }
    .tab-body {
      width: 400px;
      height: 398px;
      border: 1px solid #ccc;
    }
    .tab .item {
      display: none;
      padding-left: 30px;
    }
    .tab-head li {
      float: left;
      width: 100px;
      height: 50px;
      text-align: center;
      line-height: 50px;
      cursor: pointer;
    }
    /*让下方的内容显示*/
    .item.selected{
      display: block;
    }
    /*让上方li标签改变颜色*/
    .active{
      background-color: hotpink;
    }
  </style>
</head>
<body>
<div class="tab">
  <ul class="tab-head">
    <li class="active">页签1</li>
    <li >页签2</li>
    <li >页签3</li>
    <li >页签4</li>
  </ul>
  <div class="tab-body">
    <div class="item selected">
      <p>内容1</p>
      <p>内容1</p>
      <p>内容1</p>
      <p>内容1</p>
    </div>
    <div class="item">
      <p>内容2</p>
      <p>内容2</p>
      <p>内容2</p>
      <p>内容2</p>
    </div>
    <div class="item">
      <p>内容3</p>
      <p>内容3</p>
      <p>内容3</p>
      <p>内容3</p>
    </div>
    <div class="item">
      <p>内容4</p>
      <p>内容4</p>
      <p>内容4</p>
      <p>内容4</p>
    </div>
    </div>
  </div>
<!--jq代码实现过程-->
<script src="http://libs.baidu.com/jquery/2.0.0/jquery.min.js"></script>
<!--//引入自己写的方法-->
<script src="jQuery-tabs.js"></script>
<script>
  $ ( function () {
    //先自己写一个jQuery-tabs方法(相当于js插件)
    // 调用自己写的方法
    $('#wrapper').tabs(
      {
        tabHeads:'.tab-head>li',
        tabHeadsClass:'active',
        tabBodys:'.tab-body>div',
        tabBodysClass:'selected'
      }
    )
  } )
</script>
</body>
</html>

感兴趣的朋友可以使用在线HTML/CSS/JavaScript代码运行工具:http://tools.3water.com/code/HtmlJsRun测试上述代码运行效果。

希望本文所述对大家jQuery程序设计有所帮助。

jQuery 相关文章推荐
原生Aajax 和jQuery Ajax 写法个人总结
Mar 24 jQuery
jquery仿京东商品放大浏览页面
Jun 06 jQuery
jQuery.form.js的使用详解
Jun 14 jQuery
解决JQuery全选/反选第二次失效的问题
Oct 11 jQuery
Angular5中调用第三方库及jQuery的添加的方法
Jun 07 jQuery
jQuery插件实现的日历功能示例【附源码下载】
Sep 07 jQuery
jQuery实现网页拼图游戏
Apr 22 jQuery
使用jQuery mobile NuGet让你的网站在移动设备上同样精彩
Jun 18 jQuery
jQuery实现文本显示一段时间后隐藏的方法分析
Jun 20 jQuery
Jquery属性的获取/设置及样式添加/删除操作技巧分析
Dec 23 jQuery
jQuery实现聊天对话框
Feb 08 jQuery
JQuery实现折叠式菜单的详细代码
Jun 03 jQuery
jQuery实现的五星点评功能【案例】
Feb 18 #jQuery
jQuery实现的隔行变色功能【案例】
Feb 18 #jQuery
jQuery实现ajax的嵌套请求案例分析
Feb 16 #jQuery
jQuery实现简单的Ajax调用功能示例
Feb 15 #jQuery
jQuery实现经典的网页3D轮播图封装功能【附源码下载】
Feb 15 #jQuery
详解JavaScript原生封装ajax请求和Jquery中的ajax请求
Feb 14 #jQuery
Jquery实现无缝向上循环滚动列表的特效
Feb 13 #jQuery
You might like
咖啡与牛奶
2021/03/03 冲泡冲煮
PHP 截取字符串专题集合
2010/08/19 PHP
php代码运行时间查看类代码分享
2011/08/06 PHP
[原创]PHP实现逐行删除文件右侧空格的方法
2015/12/25 PHP
PHP常用操作类之通信数据封装类的实现
2017/07/16 PHP
Laravel5.5 数据库迁移:创建表与修改表示例
2019/10/23 PHP
javascript脚本调试方法小结
2008/11/24 Javascript
5款Javascript颜色选择器
2009/10/25 Javascript
javascript 跳转代码集合
2009/12/03 Javascript
基于node.js的快速开发透明代理
2010/12/25 Javascript
JavaScript常用全局属性与方法记录积累
2013/07/03 Javascript
纯css+js写的一个简单的tab标签页带样式
2014/01/28 Javascript
【经验总结】编写JavaScript代码时应遵循的14条规律
2016/06/20 Javascript
微信小程序 删除项目工程实现步骤
2016/11/10 Javascript
Node.js查找当前目录下文件夹实例代码
2017/03/07 Javascript
EasyUI中的dataGrid的行内编辑
2017/06/22 Javascript
浅谈angularJs函数的使用方法(大小写转换,拷贝,扩充对象)
2018/10/08 Javascript
express中static中间件的具体使用方法
2019/10/17 Javascript
wxpython学习笔记(推荐查看)
2014/06/09 Python
Python2.x版本中cmp()方法的使用教程
2015/05/14 Python
Python实现对字符串的加密解密方法示例
2017/04/29 Python
python 3调用百度OCR API实现剪贴板文字识别
2018/09/04 Python
pytorch中如何使用DataLoader对数据集进行批处理的方法
2019/08/06 Python
Python3实现配置文件差异对比脚本
2019/11/18 Python
window环境pip切换国内源(pip安装异常缓慢的问题)
2019/12/31 Python
Python 合并拼接字符串的方法
2020/07/28 Python
html5实现canvas阴影效果示例
2014/05/07 HTML / CSS
HTML5 FileReader对象的具体使用方法
2020/05/22 HTML / CSS
英国办公用品商店:Office Outlet
2018/04/04 全球购物
菲律宾优惠券网站:MetroDeal
2019/04/12 全球购物
市场营销求职信范文
2014/02/21 职场文书
中秋节主持词
2014/04/02 职场文书
建筑工地门卫岗位职责
2014/04/30 职场文书
学生检讨书怎么写
2014/10/09 职场文书
党支部创先争优公开承诺书
2015/04/30 职场文书
幼儿园2016圣诞节活动总结
2016/03/31 职场文书