2.5.6 自定义过滤器

  jQuery 中有两种方法创建自定义的过滤器。第一种比较简单,但是不鼓励,从 jQuery 1.8 开始已经被第二种方法取代。记住,使用新方法时,你自定义的过滤器在 jQuery 1.8 之前的版本不可用。

假设一个编程技术游戏。该游戏很多级别,可以区分不同的难度,用户可以获取分数,可以获取不同的编程技能。

<ul class="levels">
<li data-level="1" data-points="1" data-technologies="javascript node grunt">Level 1</li>
<li data-level="2" data-points="10" data-technologies="jquery requirejs">Level 2</li>
<li data-level="3" data-points="100" data-technologies="php composer">Level 3</li>
<li data-level="4" data-points="1000" data-technologies="javascript jquery backbone">Level 4</li>
</ul>

  假如经常要选择数据级别(data-level)大于2,获取的数据分数(data-points)大于100的游戏,且包含 jQuery 技术的(data-technologies)。但是如何使用选择器进行打两的对比呢?事实上,不可以。为了完成这个任务,必须初始化集合,然后获取需要的元素:

//li[data-technologies~="jquery"] 相当于 li[data-technologies*="jquery"]
var $levels = $('.levels li[data-technologies~="jquery"]');
var mathchedLevels = [];
for (var i = 0; i < $levels.length; i++) {
if ($levels[i].getAttribute('data-level') > 2 &&
$levels[i].getAttribute('data-points') > 100)
mathchedLevels.push($levels[i]);
};

创建自定义过滤器可以不用每次重复:

$.expr[':'].requiredLevel = $.expr.createPseudo(function(filterParam) {
return function(element, context, isXml) {
return element.getAttribute('data-level') > 2 &&
element.getAttribute('data-points') > 100;
};
});

过滤器只是一个添加了属性:的函数,它属于jQuery的 expr 属性。它是一个称为“冒号(colon)”的属性。:属性是一个包含jQuery原声过滤器的属性,可以使用它添加自己的代码。

  你可以调用自定义过滤器requiredLevel,而不是直接传递这个函数。

$('.levels li:requiredLevel')

也可以使用称为 createPseudo 的jQuery工具(它属于底层的Sizzle选择器引擎)。

对于 createPseudo() 函数,可以传递匿名方法,声明一个参数叫 filterParam。filter Param标识过滤器参数,这个参数也可以另外起名字。它是一个可选参数,与 :eq()nth-child() 类似。在匿名函数内部,可以创建另外一个匿名函数,用来执行特定的过滤器工作。在函数内,jQuery 传递要处理的元素(element参数),从这些 Dom Element 或 Dom Document 对象(上下文参数)里进行查询。Boolean 类型的参数勇于指定是不是处理 XML文档(isXML参数)。在最内层的函数里,可以编写代码来测试元素是否被保留。

前面一个例子引入了参数filterParam,可以向自定义过滤器传递参数。因为需求是固定的,所以没有使用它。现在来看看使用它帮助我们完成工作。

假设要根据提供的分数来查找特定的级别,比如“选择分数大于X的所有级别”。这是一个要使用参数传递给自定义伪选择器的好机会,基于现在的需求。

$.expr[':'].pointsHigherThan = $.expr.createPseudo(function (filterParam) {
var points = parseInt(filterParam, 10);//缓存的参数,可以在函数闭包内访问
return function (element, context, isXml) {
return element.getAttribute('data-points') > points;
};
});

这里使用的是 createPseudo() 函数,但调用的是 pointsHigherThan 过滤器、在声明第二个函数前,需要在变量 points 中保存参数。所以,它可以在闭包里访问。此时,可以通过存储的变量来使用给定的参数。



看看允许你获取50分以上的级别。

var $higherPointsLevels = $('.levels li:pointsHigherThan(50)');

2.选择元素 - 自定义过滤器《jquery实战》的更多相关文章

  1. jQuery 实战读书笔记之第二章:选择元素

    基本选择器 html 代码如下,后面的 js 使用的 html 基本大同小异. <!doctype html> <html> <head> <title> ...

  2. Jquery 系列(2) 选择元素

    Jquery基础学习 jQuery利用css选择符的能力,能够在DOM中快捷而轻松地获取元素. 主要内容如下: 介绍DOM树 如何通过CSS选择符在页中查找元素 扩展jQuery标准的CSS选择符 选 ...

  3. JQuery基础教程:选择元素(中)

    自定义选择符 JQuery在各种CSS选择符的基础上还添加了独有的完全不同的自定义选择符,注意,只要可能,jQuery就会使用浏览器原生的DOM选择符引擎去查找元素.但在使用自定义选择符的时候,就无法 ...

  4. 初识jQuery,八字真言“选择元素,对其操作”

    jQuery在我印象中,就是很多类似$(),然后昨天开始接触了,觉得很和谐,获取元素比JavaScript简单很多,有意思. 一.开始学习jQuery,下载jQuery库的文件 http://jque ...

  5. jQuery——选择元素

    ###理解DOM jQuery最强大的特性之一就是能够简化在DOM中选择元素的任务.**DOM(文档对象模型)**充当了JavaScript与网页之间的接口,它以对象网络而非纯文本的形式来表现HTML ...

  6. 抛弃jQuery:DOM API之选择元素

    原文链接:http://blog.garstasio.com/you-dont-need-jquery/selectors/ 我的Blog:http://cabbit.me/you-dont-need ...

  7. JQuery基础教程:选择元素(上)

    jQuery最强大的特性之一就是它能够简化在DOM中选择元素的任务,DOM中的对象网络与家谱有几分类似,当我们提到网络中元素之间的关系时,会使用类似描述家庭关系的术语,比如父元素.子元素,等等.通过一 ...

  8. jQuery选择器对应的DOM API ——选择元素

    英文原文:http://blog.garstasio.com/you-dont-need-jquery/selectors/愚人码头注: 原作者的写这文章的意图是让我们抛弃jQuery,You Don ...

  9. JQuery官方学习资料(译):选择元素

    选择元素     JQuery最基本的概念是“选择一些元素并让它们做些什么”.JQuery支持大部分的CSS3的选择器,以及一些非标准的选择器. 通过ID选择元素 $( "#myId&quo ...

随机推荐

  1. fgt2eth Script

    fgt2eth Script explanation_on_how_to_packet_capture_for_only_certain_TCP_flags_v2.txt Packet capture ...

  2. Android应用如何跳转到应用市场详情页面

    Android应用开发过程中,可能会有需求,比如:推广时跳转到应用市场下载应用,跳转到应用市场给自己的应用打分,跳转到应用市场更新自己的应用.那如何跳转到应用市场呢?可能跳转的方法大家都是知道的,方法 ...

  3. 洛谷 P2542 [AHOI2005]航线规划 解题报告

    P2542 [AHOI2005]航线规划 题目描述 对Samuel星球的探险已经取得了非常巨大的成就,于是科学家们将目光投向了Samuel星球所在的星系--一个巨大的由千百万星球构成的Samuel星系 ...

  4. ASP.NET MVC验证框架中关于属性标记的通用扩展方法

    http://www.cnblogs.com/wlb/archive/2009/12/01/1614209.html 之前写过一篇文章<ASP.NET MVC中的验证>,唯一的遗憾就是在使 ...

  5. adb logcat介绍

    logcat命令语法: [adb] logcat [<option>] ... [<filter-spec>] ... adb logcat -c 清除所有以前的日志 adb ...

  6. 【hihocoder】二分·归并排序之逆序对

    描述 在上一回.上上回以及上上上回里我们知道Nettle在玩<艦これ>.经过了一番苦战之后,Nettle又获得了的很多很多的船.这一天Nettle在检查自己的舰队列表:我们可以看到,船默认 ...

  7. C#利用Zxing.net生成条形码和二维码并实现打印的功能

        开篇:zxing.net是.net平台下编解条形码和二维码的工具. 下载地址:http://pan.baidu.com/s/1kTr3Vuf Step1:使用VS2010新建一个窗体程序项目: ...

  8. P3173 [HAOI2009]巧克力 && P1324 矩形分割

    题目描述 出于某些方面的需求,我们要把一块N×M的木板切成一个个1×1的小方块. 对于一块木板,我们只能从某条横线或者某条竖线(要在方格线上),而且这木板是不均匀的,从不同的线切割下去要花不同的代价. ...

  9. C语言复习---零散补充

    一:double和float使用scanf获取数据 printf输出float和double都可以用%f,double还可以用%lf. 2 scanf输入float用%f,double输入用%lf,不 ...

  10. [转载]Brackets - 强大免费的开源跨平台Web前端开发工具IDE (HTML/CSS/Javascript代码编辑器)

    http://brackets.io/ Brackets 是一个免费.开源且跨平台的 HTML/CSS/JavaScript 前端 WEB 集成开发环境 (IDE工具).该项目由 Adobe 创建和维 ...