Jquery真的不难~第二回 选择器的使用及性能
在写完第一回之后,看到了朋友们的回复,指出了我代码中的一些问题,确实由于时间仓促没有使用IDE,直接搞上了,又由于本人记忆力不好,所以把大小写都忘记了,还好晚上回家,用VS改了一下,呵呵,真是对不住大家了。
从这一讲开始,我们将直正接触一个JQ类库,学习一下JQ的写法,JQ的一些常用的命令等等,今天主要讲的是JQ里的选择器,这也是JQ的一大特点,这从它的名称jQuery中可以看到,主要功力体现在查询上。
前言:对于写在<script></script>中的代码,一般在JS环境,我们一般把代码写在window.onload=function(){...}代码块里,这个意思是说,当页面加载完成后,再执行JS代码块,而对于JQ来说,它也有类似的方法$(function(){...});我们把代码段写在这里面。有时如果不想那样写(这样写一般把JS代码放在了<head></head>标记里,但这样会影响页面加载的速度),可以把JS代码写在<body></body>的最底下。
ID选择器
alert($("#name").val()); //输出ID为name的input元素的值
类选择器
alert($(".nameclass").val()); //输出具有css名为nameclass的input元素的值
特殊选择器
alert($("input[type=text][name=name]").val()) //输出类型为text,name为name的input元素的值
//选中指定的select元素: function chekStatus(o) { $('#OrderStatus').find('option[value=' + o + ']').attr('selected', true); $('#search_btn').trigger(); } //全选 $('#SelectAll').click(function() { if (this.checked) { $('.forShop:not(:checked)').each(function() { this.click(); }); } else { $('.forShop:checked').each(function() { this.click(); }); } }); //是否有选中项 $('#delSelectProduct').click(function() { if ($('.protuctitem:checked').size() == 0) { alert('请选择宝贝'); return false; } //根据索引,选中指定的option,并为option添加CSS样式 function chekStatus(o) { $('#OrderStatus').find('option')[o].selected = true; $($('#tabs').find('dd').removeClass('cur')[o]).addClass('cur'); $('#search_btn').trigger('click'); } //为表格的行加隔行变色特效,单击行后,再变色 var $trs = $("#baike_div>table>tbody>tr"); //选择所有行 $trs.filter(":odd").addClass("odd"); //给奇数行添加odd样式 $trs.filter(":even").addClass("even"); //给偶数行添加odd样式
下面有一些选择器的技巧,需要我们去了解
//(1)通配符: $("input[id^='code']"); //id属性以code开始的所有input标签 $("input[id$='code']"); //id属性以code结束的所有input标签 $("input[id*='code']"); //id属性包含code的所有input标签 //(2)根据索引选择 $("tbody tr:even"); //选择索引为偶数的所有tr标签 $("tbody tr:odd"); //选择索引为奇数的所有tr标签 //(3)获得jqueryObj下一级节点的input个数 jqueryObj.children("input").length; //(4)获得class为main的标签的子节点下所有<a>标签 $(".main > a"); //(5)选择紧邻标签 jqueryObj.next("div"); //获取jqueryObj标签的后面紧邻的一个div,nextAll获取所有 // (6)根据索引选择 $("div").eq(0); //获取第一个div标签 //筛选器 $("#code input:not([id^='code'])"); //id为code标签内不包含id以code开始的所有input标签
上面我列出了项目中经常用到了一些选择器,事实上只要理解了它们的直正含义,我们每个人都可以写了特定的JQ代码,当然代码的效率是否高效还需要我们自己进一步的努力,
总之实现基本的需求的功能,只是第一步!
小知识:$("#...")这些选择器的返回值其时是一个JQ对象,而它可以直接操作JQ的内部事件,如click,mouseover等事件
好了,总算是把JQ选择器这块写完了,谢谢您的阅读!
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】博客园社区专享云产品让利特惠,阿里云新客6.5折上折
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 一个费力不讨好的项目,让我损失了近一半的绩效!
· .NET Core 托管堆内存泄露/CPU异常的常见思路
· PostgreSQL 和 SQL Server 在统计信息维护中的关键差异
· C++代码改造为UTF-8编码问题的总结
· DeepSeek 解答了困扰我五年的技术问题
· 清华大学推出第四讲使用 DeepSeek + DeepResearch 让科研像聊天一样简单!
· 实操Deepseek接入个人知识库
· 易语言 —— 开山篇
· 一个费力不讨好的项目,让我损失了近一半的绩效!
· 【全网最全教程】使用最强DeepSeekR1+联网的火山引擎,没有生成长度限制,DeepSeek本体