jQuery自定义选择器

jQuery 1.8版本后, 可以通过$ 的createPseudo()方法自定义选择器,满足不同的需求,本文来自<jquery in action>

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

1.选择等级高于2的, 分数高于100的li

$.expr[":"].requireLevel = $.expr.createPseudo(function(param) {return function(element, context, isXML) {return element.getAttribute("data-level") > 2 && element.getAttribute("data-points") > 100;}
})
$("ul li:requireLevel(2, 100)").css({"color": "aqua","background": "yellow"
});

 

2.选择分数高于50的

$.expr[":"].highPoint = $.expr.createPseudo(function(param) {var points = parseInt(param, 10);  //缓存参数,以便下面闭包环境中能使用return function(element, context, isXML) {return  element.getAttribute("data-points") > points;}
})
$("ul li:highPoint(50)").css({
"fontSize": "1.4em"
});

 

3.几个选择器

1 选择所有没有子节点,在文档中位置为偶数,并且不包含wrapper类名的所有div
  $("div:empty:even:not(.wrap)")

2 选择form中第一个元素是input,类型为password,并且包含required特性 的 input
  $("input[required]:password:first-child", "form")

3 选择所有的a, p,其祖先元素为div
  $("div a, div p") 或者 $("a, p", "div")

4 选择元素只包含数字,字符, 或下划线(使用自定义选择器)
  $.expr[":"].onlyText = $.expr.createPseudo(function (filterParam) {
    return function(element, context, isXML) {
       return element.innerHTML.match("/^\w+$/");
      } 
  });

 

转载于:https://www.cnblogs.com/JamesSawyer/p/5739887.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/271196.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

项目管理基础:软件生命周期概念介绍

1、软件生命周期定义软件产品或软件系统要经历孕育、诞生、成长、成熟、衰亡等阶段称为软件的生命周期。2、软件生命周期阶段组成软件的生命周期由可行性分析与项目开发计划、需求分析、总体设计、详细设计、编码、单元测试、综合测试、维护阶段。2.1 可行性分析与项目开发计划…

jvm栈和寄存器

jvm栈和寄存器 总结

python模型_python 模型的释义

CharField#字符串字段, 用于较短的字符串.#CharField 要求必须有一个参数 maxlength, 用于从数据库层和Django校验层限制该字段所允许的最大字符数.IntegerField用于保存一个整数.FloatField# 一个浮点数. 必须 提供两个参数:## 参数 描述# max_digits 总位数(不包括小数点和符…

java 布尔表达式_java - 布尔值,条件运算符和自动装箱

java - 布尔值&#xff0c;条件运算符和自动装箱为什么抛出falsepublic static void main(String[] args) throws Exception {Boolean b true ? returnsNull() : false; // NPE on this line.System.out.println(b);}public static Boolean returnsNull() {return null;}虽然…

安装你自己的perl modules

来源&#xff1a; http://www.cnblogs.com/itech/archive/2012/12/17/2822044.html 安装你自己的perl modules。当没有root权限的时候&#xff0c;需要安装perl modules到自己的home目录下。 来自&#xff1a;http://servers.digitaldaze.com/extensions/perl/modules.html Ins…

项目管理基础:项目的生存周期模型

1、概念介绍软件生命周期模型是一个包含软件产品开发、运行和维护中有关过程、活动和任务的框架&#xff0c;它覆盖了系统从需求定义到系统使用的结束阶段。特点&#xff1a;描述了开发的主要阶段定义了每个阶段需要完成的任务和过程规范了每个阶段的输入输出提供了一个标准框架…

jps显示当前所有java进程pid

很多Java命令都在jdk的JAVA_HOME/bin/目录下面&#xff0c;jps也不例外&#xff0c;他就在bin目录下&#xff0c;所以&#xff0c;他是java自带的一个命令。 jps(Java Virtual Machine Process Status Tool) 是java提供的一个显示当前所有java进程pid的命令&#xff0c;适合在…

jvm内存结构_浅谈JVM内存结构

JVM 可以分为 5 个部分&#xff0c;分别是&#xff1a;类加载器&#xff08;Class Loader&#xff09;&#xff1a;加载字节码文件到内存。运行时数据区&#xff08;Runtime Data Area&#xff09;&#xff1a;JVM 核心内存空间结构模型。执行引擎&#xff08;Execution Engine…

java annotation应用_java Annotation的应用

一、Annotation 示例Override Annotation1 Override2 public void onCreate(Bundle savedInstanceState);二、Annotation 概念及作用1 概念An annotation is a form of metadata, that can be added to Java source code. Classes, methods, variables, parameters and package…

鸿蒙和安卓,到底有什么区别?

对于开发者来说两个最关键的点值得关注&#xff1a;一个是 Beta 版的开发工具&#xff0c;一个是开源网站。开源网站在开发者大会上宣布将 HarmonyOS源代码捐赠给中国开放原子开源基金会&#xff0c;并在大会上公布了鸿蒙系统的开源路线。OpenHarmony 官方源码地址&#xff1a;…

错题集03

(选择一项) 3A: B: C: D: 正确答案是 B解析:LinkedList是实现List,Collection接口,是链表方式进行构建的,根据开发要求不同,可以使用LinkedList实现栈(先进先出)和堆(先进后出)这样的数据结构。(选择一项) 4A: B: C: D: 正确答案是 C解析&#xff1a;由于Hashtable是线程…

从零开始学python人工智能课程_从零开始如何学习人工智能?

想要学习人工智能&#xff1f;这里有一条完整路径资源在本文中&#xff0c;《Analytics India》杂志给出了学习AI的最佳途径。...科技领域的天平正在向人工智能倾斜&#xff0c;IT领域的技术人员正在将AI应用到现有产品中。但是对于企业来说&#xff0c; AI人才才是关键。企业培…

项目管理基础:软件开发的方法介绍

软件开发方法主要有结构化方法、原型化方法、面向对象开发方法、敏捷方法。1、结构化方法结构化方法由结构化分析、结构化设计、结构化程序设计组成&#xff0c;它是一种面向数据流的开发方法。结构化分析&#xff1a;依据分解与抽象的原则&#xff0c;按照系统中数据处理的流程…

类加载器子系统的作用

类加载器子系统的作用

Magento Block设计分析(深入分析)

Magento中Block是一个很重要的组件&#xff0c;它在Block中充当非常重要的角色&#xff0c;下面我们来分析一下Magento中Block是怎样设计的&#xff0c;我们应该怎样使用这个重要的角色。1、Magento Block类图: 图1: 继承Varien_Object的对象都有一个_data类变量&#xff0c;用…

JAVA输出x和y和z_JAVA实例:输入三个整数x,y,z,请把这三个数由小到大输出-吾爱编程网...

今天为大家分享一个java经典实例输入三个整数x,y,z,请把这三个数由小到大输出&#xff0c;相信很多初学者都会学到这道题目&#xff0c;接下来吾爱编程为大家介绍一下程序的相关写法&#xff0c;有需要的小伙伴可以参考一下:1、题目&#xff1a;输入三个整数x,y,z&#xff0c;请…

软件项目管理相关概念介绍笔记

1、成本估算由于软件项目具有可见性差、难定量化的特点&#xff0c;一般情况下很难在项目完成前准确的评估软件项目开发的工作量和费用。通常会根据以往开发类似项目的经验来进行成本估算。也可以将整个项目划分为若干个子系统或按照软件的生命周期的各个阶段分别进行费用估算&…

python爬取微博热搜_Python 超简单爬取微博热搜榜数据

微博的热搜榜对于研究大众的流量有非常大的价值。今天的教程就来说说如何爬取微博的热搜榜。 热搜榜的链接是&#xff1a;用浏览器浏览&#xff0c;发现在不登录的情况下也可以正常查看&#xff0c;那就简单多了。使用开发者工具(F12)查看页面逻辑&#xff0c;并拿到每条热搜的…

LeetCode14 Longest Common Prefix

题意&#xff1a; Write a function to find the longest common prefix string amongst an array of strings. (Easy) 这两天实验室项目太忙了&#xff0c; 老板各种活&#xff0c;只能挑着先水几道easy题&#xff0c;这两个题是昨天做的没来得及写总结。 分析&#xff1a; 暴…

类加载器ClassLoader的角色

类加载器ClassLoader的角色