• Jquery属性选择器(同时匹配多个条件,与或非)(附样例)


    (转)

    1. 前言

    为了处理除了两项不符合条件外的选择,需要用到jquery选择器的多个条件匹配来处理,然后整理了一下相关的与或非的条件及其组合。

    作为笔记记录。

    2. 代码

    <!DOCTYPE html>
    <html>
    <head>
    	<title>Test multi selection</title>
    	<script src="http://apps.bdimg.com/libs/jquery/2.1.4/jquery.min.js"></script>
    	<script type="text/javascript">
    
    	$().ready(function(){
    		
    		debugger;// open console and click F10
    		//多条件选择
    		$('#td1,#td2,p').css('color','red'); 
    		//选择内容不是id=td1
    		$('tbody td:not(#td1)').css('color','green'); 
    		//选择条件1 attr1="a1" 和 条件2 attr2="a2"的元素
    		$('[attr1="a1"][attr2="a2"]').css('color','blue'); 
    		//选择条件1 attr1="a1" 或者 条件2 attr2="a2"的元素
    		$('[attr1="a1"],[attr2="a2"]').css('color','yellow');
    
    		//选择不满足 条件1 attr1="a1" 的元素
    		$('tbody td[attr1!="a1"]').css('color','purple'); 
    		
    		//选择不满足 条件1 attr1="a1" 或 条件2 attr2="a2"的元素
    		$('tbody td:not([attr1="a1"],[attr2="a2"])').css('color','orange');
    		$('tbody td[attr1!="a1"][attr2!="a2"]').css('color','black');
    
    		//选择不满足 条件1 attr1="a1" 和 条件2 attr2="a2"的元素
    		$('tbody td:not([attr1="a1"][attr2="a2"])').css('color','#ff7700');
    		$('tbody td[attr1!="a1"],tbody td[attr2!="a2"]').css('color','black');
    
    		//选择tboy中td标签attr1!="a1" 和 所有标签中attr2!="a2", 即除了<td id="td3" attr1="a1" attr2="a2">3</td>的其它所有标签元素
    		$('tbody td[attr1!="a1"],[attr2!="a2"]').css('color','grey');
    	})
    
    	</script>
    </head>
    <body>
    <table border="1px">
    	<thead>
    		<tr>
    			<td>One</td>
    			<td>Two</td>
    			<td>Three</td>
    			<td>Four</td>
    			<td>Five</td>
    		</tr>
    	</thead>
    	<tbody>
    		<tr>
    			<td id="td1">1</td>
    			<td id="td2">2</td>
    			<td id="td3" attr1="a1" attr2="a2">3</td>
    			<td id="td4" attr1="a1">4</td>
    			<td id="td5">5</td>
    		</tr>
    	</tbody>
    </table>
    <p>I am first paragraph </p>
    </body>
    </html>  

    3. 效果

    //多条件选择
    $('#td1,#td2,p').css('color','red');

    //选择内容不是id=td1
    $('tbody td:not(#td1)').css('color','green'); 

    //选择条件1 attr1="a1" 和 条件2 attr2="a2"的元素
    $('[attr1="a1"][attr2="a2"]').css('color','blue');
    

    //选择条件1 attr1="a1" 或者 条件2 attr2="a2"的元素
    $('[attr1="a1"],[attr2="a2"]').css('color','yellow');

    //选择不满足 条件1 attr1="a1" 的元素
    $('tbody td[attr1!="a1"]').css('color','purple');

    //选择不满足 条件1 attr1="a1" 或 条件2 attr2="a2"的元素
    $('tbody td:not([attr1="a1"],[attr2="a2"])').css('color','orange');

    //选择不满足 条件1 attr1="a1" 或 条件2 attr2="a2"的元素(等价于上一条)
    $('tbody td[attr1!="a1"][attr2!="a2"]').css('color','black');

    //选择不满足 条件1 attr1="a1" 和 条件2 attr2="a2"的元素
    $('tbody td:not([attr1="a1"][attr2="a2"])').css('color','#ff7700');
    

    //选择不满足 条件1 attr1="a1" 和 条件2 attr2="a2"的元素(等价于上一条)
    $('tbody td[attr1!="a1"],tbody td[attr2!="a2"]').css('color','black'); 

    //选择tboy中td标签attr1!="a1" 和 所有标签中attr2!="a2", 即除了<td id="td3" attr1="a1" attr2="a2">3</td>的其它所有标签元素
    $('tbody td[attr1!="a1"],[attr2!="a2"]').css('color','grey');
    

    4. 参考

    http://www.runoob.com/jquery/jquery-ref-selectors.html

  • 相关阅读:
    .NET Core技术研究-通过Roslyn代码分析技术规范提升代码质量
    ASP.NET Core技术研究-全面认识Web服务器Kestrel
    .NET Core技术研究-主机Host
    ASP.NET Core技术研究-探秘依赖注入框架
    ASP.NET Core技术研究-探秘Host主机启动过程
    .NET Core技术研究-中间件的由来和使用
    深入浅出腾讯BERT推理模型--TurboTransformers
    深入浅出PyTorch(算子篇)
    深入浅出Transformer
    生产者消费者问题总结
  • 原文地址:https://www.cnblogs.com/jkfeng/p/12069974.html
Copyright © 2020-2023  润新知