06-jQuery过滤选择器-基本&可见过滤

jQeury过滤选择器-基本&可见过滤

作者:曾庆林

过滤选择器主要是通过特定的过滤规则来筛选出需要的DOM元素,过滤规则与CSS中的伪类选择器语法相同,即过滤选择器都是以冒号:开头。

过滤选择器分类:

  • 基本过滤选择器
  • 内容过滤选择器
  • 可见性过滤选择器
  • 属性过滤选择器
  • 子元素过滤选择器
  • 表单对象属性过滤选择器

基本过滤选择器

选择器 描述 返回 示例
:first 选择第1个元素 单个元素 $(“div:first”)选择第1个div元素
:last 选择最后1个元素 单个元素 $(“div:last”)选择最后1个div元素
:not(E1) 去除所有E1选择器匹配的元素 集合元素 $(“input:not(.my)”)选择class不是.my的所有input元素
:even 选择索引是偶数的所有元素,索引从0开始 集合元素 $(“tr:even”)选择表格中所有偶数的行
:odd 选择索引是奇数的所有元素,索引从0开始 集合元素 $(“tr:odd”)选择表格中所有奇数的行
:eq(index) 选择索引值是index的元素,index从0开始 单个元素 $(“tr:eq(1)”)选择表格行索引等于1的行
:gt(index) 选择索引值大于index的元素,index从0开始 集合元素 $(“tr:gt(1) ”)选择表格行索引大于1的行
:lt(index) 选择索引值小于index的元素,index从0开始 集合元素 $(“tr:lt(1)”)选择表格行索引小于1的行
:header 所取所有的标题元素,h1~h6 集合元素 $(“:header”)选择网页中所有的<h1>,<h2>…<h6>
:animated 选择当前正在执行动画的所有元素 集合元素 $(“div:animated”)选择正在执行动画的div元素

内容过滤选择器

选择器 描述 返回值 示例
:contains(text) 选择含有text文本内容的元素 集合元素 $(“div:contains(‘我’)”)选择内容里包含我的所有div
:empty 选择不包含子元素或文本的空元素 集合元素 $(“div:empty”)选择不包含子元素(含文本)的所有div元素
:has(E1) 选择包含有(E1选择器匹配的元素)的所有元素 集合元素 $(“div:has(p)”)选择含有p元素的所有div元素
:parent 选择含有子元素或文本的元素 集合元素 $(“div:parent”)选择拥有子元素(包含文本)的所有div元素

可见性过滤选择器

选择器 描述 返回值 示例
:hidden 选择所有不可见元素 集合元素 $(“:hidden”)选择所有不可见元素,包括:<input type=“hidden”/>,<div style=“display:none”>和<div style=“visibility:hidden”>等,如果只选择<input>元素,则可以使用 $(“input:hidden”)
:visible 选择所有可见元素 集合元素 $(“div:visible”)选取所有可见的div元素

案例-tab切换 可见过滤

思路

单击第几个,显示第几个,以前显示的隐藏  

html结构

<div id="tab1" class="tabs">
            <ul>
                <li class="tab-title active">li1</li>
                <li class="tab-title">li2</li>
                <li class="tab-title">li3</li>
            </ul>
            <div class="tab-content" style="display: block;">内容1</div>
            <div class="tab-content" >内容2</div>
            <div class="tab-content">内容3</div>
</div>

css 部分

* {
    margin: 0;
        padding: 0;
}
            
body {
    padding: 50px;
}

ul {
    list-style: none;
}

.tabs .tab-title {
    height: 35px;
    line-height: 35px;
    border: 1px solid #aaa;
    padding-left: 15px;
    padding-right: 15px;
    float: left;
    margin-right: 15px;
    position: relative;
    z-index: 10;
}

.tabs .active{border-bottom-color:#fff; color: #F80;}
.tabs .tab-content {
    clear: both;
    border: 1px solid #aaa;
    padding: 25px;
    width: 450px;
    height: 300px;
    display: none;
    position: relative;
    top: -1px;
    z-index: 0;
}
#tab2 .tab-content{width: 800px;}

js写法

//[1] 单击第几个,显示第几个,以前显示的隐藏
$(function(){
    $(".tab-title").click(function(){
        //以前显示的现在隐藏
        $(".tab-content:visible").hide();
        // 求出是第几个
        var num=$(".tab-title").index($(this));
        $(".tab-content:eq("+num+")").show();
        //之前有.active li 去掉active
        //当前li 添加actvie
        $(".active").removeClass("active");
        $(this).addClass("active");
    
    })
})

完整的示例


<!doctype html>
<html lang="en">

    <head>
        <meta charset="UTF-8" />
        <title>Document</title>
        <style>
            * {
                margin: 0;
                padding: 0;
            }
            
            body {
                padding: 50px;
            }
            
            ul {
                list-style: none;
            }
            
            .tabs .tab-title {
                height: 35px;
                line-height: 35px;
                border: 1px solid #aaa;
                padding-left: 15px;
                padding-right: 15px;
                float: left;
                margin-right: 15px;
                position: relative;
                z-index: 10;
            }
            
            .tabs .active{border-bottom-color:#fff; color: #F80;}
            .tabs .tab-content {
                clear: both;
                border: 1px solid #aaa;
                padding: 25px;
                width: 450px;
                height: 300px;
                display: none;
                position: relative;
                top: -1px;
                z-index: 0;
            }
            #tab2 .tab-content{width: 800px;}
        </style>
    </head>

    <body>
        <div id="tab1" class="tabs">
            <ul>
                <li class="tab-title active">li1</li>
                <li class="tab-title">li2</li>
                <li class="tab-title">li3</li>
            </ul>
            <div class="tab-content" style="display: block;">内容1</div>
            <div class="tab-content" >内容2</div>
            <div class="tab-content">内容3</div>
        </div>
    <script src="js/jquery-1.4.2.min.js"></script>
    <script>
    //[1] 单击第几个,显示第几个,以前显示的隐藏
    $(function(){
        $(".tab-title").click(function(){
            //以前显示的现在隐藏
            $(".tab-content:visible").hide();
            // 求出是第几个
            var num=$(".tab-title").index($(this));
            $(".tab-content:eq("+num+")").show();
            //之前有.active li 去掉active
            //当前li 添加actvie
            $(".active").removeClass("active");
            $(this).addClass("active");
        
        })
    })
    </script>
    

    </body>

</html>
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 211,639评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,277评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,221评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,474评论 1 283
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,570评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,816评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,957评论 3 408
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,718评论 0 266
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,176评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,511评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,646评论 1 340
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,322评论 4 330
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,934评论 3 313
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,755评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,987评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,358评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,514评论 2 348

推荐阅读更多精彩内容

  • 一、样式篇 第1章 初识jQuery (1)环境搭建 进入官方网站获取最新的版本 http://jquery.co...
    凛0_0阅读 3,358评论 0 44
  • 问答题47 /72 常见浏览器兼容性问题与解决方案? 参考答案 (1)浏览器兼容问题一:不同浏览器的标签默认的外补...
    _Yfling阅读 13,737评论 1 92
  • 由于简书很有效果不支持,欢迎移步微信公众号排版背后的技术解析查看具体的效果 单纯的微信公众号文章编辑器很难满足大家...
    李东bbsky阅读 6,534评论 0 6
  • 使用Photoshop图层样式可以为文字实现很多漂亮的效果,只要你有创意,都可以设计出不同的花样出来,今天思维...
    打豆豆阅读 12,825评论 6 57
  • 在nodejs.org里面下载.zip,.msi可能会安装过程中死机 设置环境变量,在path中添加nodejs的...
    黑山老水阅读 364评论 0 1