jquery选择器的选择使用及性能介绍

 更新时间:2013年01月16日 16:58:42   作者:  
从这一讲开始,我们将直正接触一个JQ类库,学习一下JQ的写法,JQ的一些常用的命令等等,今天主要讲的是JQ里的选择器,这也是JQ的一大特点,这从它的名称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选择器这块写完了,谢谢您的阅读!

相关文章

  • jquery UI Datepicker时间控件的使用及问题解决

    jquery UI Datepicker时间控件的使用及问题解决

    这篇文章主要介绍了jquery UI Datepicker时间控件的使用及与asp.net中的UpdatePanel联合使用时的失效问题解决,感兴趣的小伙伴们可以参考一下
    2016-04-04
  • JQuery EasyUI 加载两次url的原因分析及解决方案

    JQuery EasyUI 加载两次url的原因分析及解决方案

    这篇文章主要介绍了JQuery EasyUI 加载两次url的原因分析及解决方案,需要的朋友可以参考下
    2014-08-08
  • JQuery控制radio选中和不选中方法总结

    JQuery控制radio选中和不选中方法总结

    这篇文章主要介绍了JQuery控制radio选中和不选中方法总结,本文起讲解了设置选中方法、设置选中和不选中示例、另一种设置选中方法、根据值设置radio选中、使用prop方法操作示例等内容,需要的朋友可以参考下
    2015-04-04
  • 详解jQuery UI库中文本输入自动补全功能的用法

    详解jQuery UI库中文本输入自动补全功能的用法

    这篇文章主要介绍了详解jQuery UI库中文本输入自动补全功能的用法,其中重点讲解了常用的邮箱地址输入时后缀自动补全功能的使用,需要的朋友可以参考下
    2016-04-04
  • 基于jquery的cookie的用法

    基于jquery的cookie的用法

    jQuery.cookie.js是个很好的cookie插件,大概的使用方法如下,需要的朋友可以参考下。
    2011-01-01
  • jQuery操作CSS样式

    jQuery操作CSS样式

    这篇文章介绍了jQuery操作CSS样式的方法,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-03-03
  • Jquery ajax请求导出Excel表格的实现代码

    Jquery ajax请求导出Excel表格的实现代码

    下面小编就为大家带来一篇Jquery ajax请求导出Excel表格的实现代码。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-06-06
  • flexigrid 类似ext grid的JS表格代码

    flexigrid 类似ext grid的JS表格代码

    flexigrid是类似ext grid的JS表格,不过基于jQuery,目前只是beta版,例子不十分完整。
    2010-07-07
  • JQuery.Ajax之错误调试帮助信息介绍

    JQuery.Ajax之错误调试帮助信息介绍

    本篇文章是对JQuery.Ajax中的错误调试帮助信息进行了详细的分析介绍,需要的朋友参考下
    2013-07-07
  • 自定义刻度jQuery进度条及插件

    自定义刻度jQuery进度条及插件

    自定义刻度jq进度条可以自定义进度条刻度圆点数量,大小等相关属性,可以通过css控制圆点的外观样式,通过progressdots插件自定义刻度动画,使用该插件还需引入jquery,jquery.progressdots.js和jquery.progressdots.css文件。需要的朋友一起学习吧
    2015-09-09

最新评论