使用jQuery管理选择结果


Posted in Javascript onJanuary 20, 2015

使用jQuery选择出来的元素与数组非常类似,可以通过jQuery提供的一系列方法对其进行处理,包括长度、查找某个元素,截取某个段落等。

1.获取元素的个数。

在jQuery中可以通过size()方法获取选择器中元素的个数,它类似数组中的length属性,返回整数值,例如:

$("img").size()
获取页面中,所有图片<img>的数目

如下是一个实例,通过不断的点击添加div块并计算页面中的<div>块。

<style>

            div {

                border: 1px solid #003a75;

                background-color: #FFFF00;

                margin: 5px;

                padding: 20px;

                text-align: center;

                height: 20px;

                width: 20px;

                float: left;

            }

        }

        </style>

        <script type="text/javascript">

            document.onclick = function() {

                var i = $("div").size() + 1; //获取div的数目,(此时还没有div块)

                $(document.body).append($("<div>" + i + "</div>")); //添加一个div块

                $("#number").html(i);

            }

        </script>

页面中一共有<span id="number">0</span>个DIV块。单击鼠标添加

2.提取元素

在jQuery中选择器中,如果想提取某个元素,最直接的方法是采用方括号加序号的形式,例如;

$("img[title]")[1]
获取了所有设置了title属性的img标记中的第二个元素。jQuery也提供了get(index)方法来提取元素,以下的代码与上面的完全等效

$("img[title]")get(1)
get方法在不设置任何参数时,可以将元素转化为一个元素对象的数组,如下的例子:

<style>

            div {

                border: 1px solid #003a75;

                background-color: #FFFF00;

                margin: 5px;

                padding: 20px;

                text-align: center;

                height: 20px;

                width: 20px;

                float: left;

            }

        }

        </style>

        <script type="text/javascript">

            function displayleb(ndiv) {

                for (var i = 0; i < ndiv.length; i++)

                    $(document.body).append($("<div style='background:"+ndiv[i].style.background + ";'>" + ndiv[i].innerHTML + "</div>"));

            }

            $(function(){

                var aDiv = $("div").get();//转化为div对象数组

                displayleb(aDiv.reverse());

            });

        </script>

        <div style="background:#FFFFFF">1</div>

        <div style="background:#CCCCCC">2</div>

        <div style="background:#999999">3</div>

        <div style="background:#666666">4</div>

        <div style="background:#333333">5</div>

        <div style="background:#000000">6</div>

上面代码将页面本身的6个<div>块用get()方法转化为数组,然后用数组反序reverse(),并传给displayleb()函数,再将其一个个现在页面中。

get(index)方法可以获取指定位置的元素,反过来,index(element)方法可以查找元素的element所处的位置。例如

var iNum=$("li").index($(li[title=isaac]")[0])
以上取<li titile="isaac">标记在整个<li>标记列表所处的位置,并将该位置返回给整数iNum.如下举例index(element)方法的典型运用。

例:用index()方法获取元素的序号

    <style>

            div {

                border: 1px solid #003a75;

                background-color: #FFFF00;

                margin: 5px;

                padding: 20px;

                text-align: center;

                height: 20px;

                width: 20px;

                float: left;

            }

        }

        </style>

        <script type="text/javascript">

            $(function() {

                //div click()添加单击函数

                $("div").click(function() {

                    //将本身通过this关键字传入,获取自身的序号。

                    var index = $("div").index(this) + 1;

                    $("#display").html(index.toString());

                })

            });

        </script>

        <div style="background:#FFFFFF">1</div>

        <div style="background:#CCCCCC">2</div>

        <div style="background:#999999">3</div>

        <div style="background:#666666">4</div>

        <div style="background:#333333">5</div>

        <div style="background:#000000">6</div>

        单击的是第<span id="display"></span>个div。

以上代码块本身用this关键字传入index()方法中,获取自身的序号,并且利用click()添加事件,将序号显示出来。

3.添加、删除、过滤元素

除了获取选择元素外,jQuery还提供了一系列的方法来修改元素集合,例如用add()的方法添加元素。

$("img[alt]").add("img[title]")
以上代码将设置了alt元素的图像和说呀设置了title属性的图像组合在一起,供别的方法统一调运。它完全等同于

$("img[alt],img[title]")
例如,可以讲组合后的元素集统一添加css属性。

$("img[alt]").add("img[title]").addClass("altcss")
与add()方法相反,not()方法可以去除元素集合中的某些元素形成集合

$("li[title]").not("[title*=isaac]")
以上代码表示,选中所有设置了title属性的标记 ,但不包括title的值中包含"isaac"的<li>。

例:

<style>

            div {

                border: 1px solid #003a75;

                background-color: #FFFF00;

                margin: 5px;

                padding: 20px;

                text-align: center;

                height: 20px;

                width: 20px;

                float: left;

            }

            .altcss {

                border: 2px solid #000000;

            }

        }

        </style>

        <script type="text/javascript">

            $(function() {

                $("div").not(".green, #blueone").addClass("altcss");

            });

        </script>

        <div></div>

        <div id="blueone"></div>

        <div></div>

        <div class="green"></div>

        <div class="green"></div>

        <div class="gray"></div>

        <div></div>

以上的Jquery通过not()的方法去掉风格为"green"和"blueone"的<div>块,给剩下的div块加altcss样式。

not()方法所接收的参数都不能包含特定的元素,只能是通过通用的表达式例如下面的代码是错误的

$("li[title]").not("img[title*=isaac]")
正确的写法是:

$("li[tile]").not("[title*=isaac]")
除了add()和not()外,jQuery还提供了更强大的filter()方法来筛选元素。filter()可以接受两种类型的参数,一种与not()方法一样,接受通用的表达式。代码如下:

$("li").filter("[title*=isaac]")
以上的代码表示:筛选出title值包含isaac字符串的li元素组合。

$("li[title*=isaac]")
所筛选的组合相同。

<script type="text/javascript">

            $(function() {

                $("div").addClass("css1").filter("[class*=middle]").addClass("css2");

            });

        </script>
        <div></div>

        <div class="middle"></div>

        <div class="middle"></div>

        <div class="middle"></div>

        <div class="middle"></div>

        <div></div>

以上代码中其中4个class属性为middle,Jq先给所有的div块都添加了css1样式,然后通过filter()方法,把class中包含middle的div添加css2样式。

在filter()的参数中,不能直接的等于匹配(=),只能使用前匹配(^=)、后匹配(&=),或者任意匹配(*=).

filter()另外一种类型的参数是函数,对于返回ture元素匹配保留,否则排除集合。函数参数功能十分强大,可以让用户自定义筛选函数。

例如:

<script type="text/javascript">

            $(function() {

                $("div").addClass("css1").filter(function(index) {

                    return index == 1 || $(this).attr("id") == "fourth";

                }).addClass("css2");

            });

        </script>      

<div id="first"></div>

    <div id="second"></div>

    <div id="third"></div>

    <div id="fourth"></div>

    <div id="fifth"></div>

以上jq执行:

将所有的div添加css1然后利用filter()返回的函数将div列表中第一个(index为1),id是fourth的div元素筛选出来,添加css2.

4.查询过滤新元素组

jq还提供了 一些很有的用的方法组合,通过查询来获取新元素组合。例如find()方法。通过匹配选择器来筛选元素

$("p").find("span")
表示查找到<p>标记下含有<span>标记的组合

完全等于

$("span",$("p"))

$(function(){

    $("p").find("span").addClass("css1");

});
<p><span>Hello</span>, how are you?</p>

表示给Hello添加css1的样式.

另外,还可以通过is()方法来检测是否包含指定的元素,例如可以通过下面代码检测页面中<div>块中是否包含图片。

var himg = $("div").is("img");
试想下,is()还可以结合filter()使用,是不是很惬意?

以上就是本文的全部内容了,虽然有点长,但是还是建议小伙伴们仔细读一下,希望大家能够喜欢。

Javascript 相关文章推荐
javascript中的107个基础知识收集整理 推荐
Mar 29 Javascript
javascript getElementsByClassName函数
Apr 01 Javascript
基于jquery的划词搜索实现(备忘)
Sep 14 Javascript
Jquery index()方法 获取相应元素索引值
Oct 12 Javascript
浅析document.ready和window.onload的区别讲解
Dec 18 Javascript
详解javascript实现自定义事件
Jan 19 Javascript
JavaScript File API实现文件上传预览
Feb 02 Javascript
关于Webpack dev server热加载失败的解决方法
Feb 22 Javascript
mui js控制开关状态、修改switch开关的值方法
Sep 03 Javascript
jquery.validate自定义验证用法实例分析【成功提示与择要提示】
Jun 06 jQuery
Vue将props值实时传递 并可修改的操作
Aug 09 Javascript
javascript对象3个属性特征
Nov 17 Javascript
javascript动态修改Li节点值的方法
Jan 20 #Javascript
js+css实现tab菜单切换效果的方法
Jan 20 #Javascript
jQuery中Ajax的get、post等方法详解
Jan 20 #Javascript
js动态切换图片的方法
Jan 20 #Javascript
JavaScript 基本概念
Jan 20 #Javascript
自己动手手写jQuery插件总结
Jan 20 #Javascript
JavaScript学习心得之概述
Jan 20 #Javascript
You might like
Thinkphp搭建包括JS多语言的多语言项目实现方法
2014/11/24 PHP
PHP上传文件及图片到七牛的方法
2018/07/25 PHP
jscript之Read an Excel Spreadsheet
2007/06/13 Javascript
javascript 选择文件夹对话框(web)
2009/07/07 Javascript
JQuery浮动DIV提示信息并自动隐藏的代码
2010/08/29 Javascript
JS获取页面窗口大小的代码解读
2011/12/01 Javascript
JS实现图片横向滚动效果示例代码
2013/09/04 Javascript
CSS+jQuery实现的一个放大缩小动画效果
2013/09/24 Javascript
Angular.Js的自动化测试详解
2016/12/09 Javascript
JavaScript 总结几个提高性能知识点(推荐)
2017/02/20 Javascript
jQuery实现注册会员时密码强度提示信息功能示例
2017/09/05 jQuery
JavaScript requestAnimationFrame动画详解
2017/09/14 Javascript
JavaScript实现计数器基础方法
2017/10/10 Javascript
Electron-vue脚手架改造vue项目的方法
2018/10/22 Javascript
JavaScript学习笔记之图片库案例分析
2019/01/08 Javascript
JS 自执行函数原理及用法
2019/08/05 Javascript
基于JS实现父组件的请求服务过程解析
2019/10/14 Javascript
JS document对象简单用法完整示例
2020/01/14 Javascript
深入理解webpack process.env.NODE_ENV配置
2020/02/23 Javascript
vue+element_ui上传文件,并传递额外参数操作
2020/12/05 Vue.js
Python中无限元素列表的实现方法
2014/08/18 Python
Python中使用异常处理来判断运行的操作系统平台方法
2015/01/22 Python
详解Python的Twisted框架中reactor事件管理器的用法
2016/05/25 Python
Python 音频生成器的实现示例
2019/12/24 Python
8种常用的Python工具
2020/08/05 Python
指针和引用有什么区别
2013/01/13 面试题
学期自我鉴定范文
2013/10/01 职场文书
《池塘边的叫声》教学反思
2014/04/12 职场文书
幼儿园师德演讲稿
2014/05/06 职场文书
小学生清明节演讲稿
2014/09/05 职场文书
企业党的群众路线教育实践活动领导班子对照检查材料
2014/09/25 职场文书
2014年仓库工作总结
2014/11/20 职场文书
新闻稿标题
2015/07/18 职场文书
物业保洁员管理制度
2015/08/05 职场文书
2016清明节森林防火广播稿
2015/12/17 职场文书
如何在向量化NumPy数组上进行移动窗口
2021/05/18 Python