千家信息网

基于jQuery排序及怎么实现Tab栏特效

发表于:2024-11-25 作者:千家信息网编辑
千家信息网最后更新 2024年11月25日,今天小编给大家分享一下基于jQuery排序及怎么实现Tab栏特效的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,
千家信息网最后更新 2024年11月25日基于jQuery排序及怎么实现Tab栏特效

今天小编给大家分享一下基于jQuery排序及怎么实现Tab栏特效的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。

一、jQuery排序

eq()排序,可以看作是一个筛选方法

  • jQuery 中获得的对象,内部包含选择的一组原生 js 对象,在 jQuery 对象中会进行一个新的大的排序,这个排序与原来的 HTML 结构没有关系。

所以eq() 方法在 jQuery 对象中通过下标获取某个对象,下标是 jQuery 对象中的大的排序的下标。

//选中所有p标签var $ps = $("p");//生成了一个jquery对象,内部包含了所有的元素js对象// 是一个类数组对象,内部会按照获取顺序进行一个大排序// 排序与自己原来的父级没有关系,只与在jQuery对象中的新的位置有关// 给指定位置对象添加颜色$ps.eq(1).css("background-color","pink")$ps.eq(4).css("background-color","skyblue")$ps.eq(8).css("background-color","purple")$ps.eq(7).css("background-color","lightgreen")$ps.eq(10).css("background-color","orange")//对所有获取的元素进行了排序,跟原来的结构没有关系

第三组div里p标签

----------

二、index()方法

  • jQuery 对象调用index() 方法时,得到的是它自己在 HTML 结构中的兄弟中的下标位置。与新生成的jQuery 对象内部的大排序没有关系。

  • 它依赖于自身元素在父级中同级元素之间的位置

//index() 兄弟中的排序$ps.click(function(){  //点击输出自己的index值  console.log($(this).index());})

上图为依次点击图中p标签后,所显示结果

  jQuery中设置排他方法,在jQuery中可以通过this特殊设置进行链式调用,让兄弟通过siblings方法,批量设置成默认效果。

三、应用:Tab栏特效中的排他

  • 自己的级别的排他:给自己this添加(要添加的属性)类名,让其他的兄弟删除该类名。

  • 对应的部分的排他:给对应位置的元素添加 (要添加的属性)类名,其他兄弟删除该类名。

  • 找对应关系,使用的是自己的index()下标,让另一组中下标相同的项作为对应项。

  • 通过选中另一组的对应项利用eq()方法选择下标项。

html部分:

  

script部分:

    上面的方法在一个tab栏中效果实现没有问题, 但是当页面有多个tab栏时,jQuery对象中大排序和index获取的顺序就会不统

出现问题

  解决方法:span和ul的查找全部使用链式调用,通过节点关系查找

jQuery 对象进行的操作都是批量操作,批量操作只能执行一些简单的效果,如果想对 JQ 对象中的每一个元素以及内部的后
代元素进行一些复杂操作,程序很难执行

each()遍历

each()的参数是一个函数

作用:对jQuery对象中的元素每一个都执行函数内部的操作

each方法基本原理就是for循环,从对象的下标为0的项一直遍历到最后一项,然后对每一项进行操作

优点:

each的函数内部也有一个this,指向的是进来遍历的每一次的元素。

 

h3

h3

each的函数可以传一个参数i,i表示的是这一次的遍历对象在整体的jQuery对象大排序中的下标位置

  //通过each()操作$ps.each(function(i){ // i 记录的是这一次遍历时,当前元素在jQuery对象大排序中的位置     $(this).click(function(){     console.log($(this).index())     //这个内部的this是事件源    console.log(i);     }) })

同理,如果想实现表格隔列变色的话,依靠jQuery大排列顺序来实现奇偶不同变色的话,后期若给表格再添加列,都会出现问题,无法对应。所以使用each()方法,将每一行作为一个操作单元,让每一行中的列进行隔列变色

var $trs = $("tr");$trs.each(function(){    $(this).children(":odd").css("background-color","skyblue");})

另一种方法就是使用td判断,只要不使用jQuery的大排序,就不会影响后期插入列

$("td").each(function(){    //判断当前td在父级中所处的位置    if($(this).index() % 2 == 0){       $(this).css("background-color","skyblue");    }})

以上就是"基于jQuery排序及怎么实现Tab栏特效"这篇文章的所有内容,感谢各位的阅读!相信大家阅读完这篇文章都有很大的收获,小编每天都会为大家更新不同的知识,如果还想学习更多的知识,请关注行业资讯频道。

0