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


Posted in Javascript onJanuary 16, 2013

在写完第一回之后,看到了朋友们的回复,指出了我代码中的一些问题,确实由于时间仓促没有使用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选择器这块写完了,谢谢您的阅读!

Javascript 相关文章推荐
JSON 数据格式介绍
Jan 13 Javascript
js离开或刷新页面检测(且兼容FF,IE,Chrome)
Mar 05 Javascript
javascript转换静态图片,增加粒子动画效果
May 28 Javascript
基于javascript实现最简单的选项卡切换效果
May 16 Javascript
jQuery中的ready函数与window.onload谁先执行
Jun 21 Javascript
JS简单实现禁止访问某个页面的方法
Sep 13 Javascript
webpack+vue.js快速入门教程
Oct 12 Javascript
Javascript 高性能之递归,迭代,查表法详解及实例
Jan 08 Javascript
基于js 本地存储(详解)
Aug 16 Javascript
Vue.js 实现微信公众号菜单编辑器功能(一)
May 08 Javascript
微信小程序使用setData修改数组中单个对象的方法分析
Dec 30 Javascript
vue实现前端分页完整代码
Jun 17 Javascript
jQuery旋转插件—rotate支持(ie/Firefox/SafariOpera/Chrome)
Jan 16 #Javascript
用JS提交参数创建form表单在FireFox中遇到的问题
Jan 16 #Javascript
体验js中splice()的强大(插入、删除或替换数组的元素)
Jan 16 #Javascript
Javascript中产生固定结果的函数优化技巧
Jan 16 #Javascript
js 在定义的时候立即执行的函数表达式(function)写法
Jan 16 #Javascript
JQuery验证工具类搜集整理
Jan 16 #Javascript
js 实现在离开页面时提醒未保存的信息(减少用户重复操作)
Jan 16 #Javascript
You might like
自己做矿石收音机
2021/03/02 无线电
解决phpmyadmin中文乱码问题。。。
2007/01/18 PHP
ThinkPHP里用U方法调用js文件实例
2015/06/18 PHP
功能强大的php文件上传类
2016/08/29 PHP
PHP7 其他修改
2021/03/09 PHP
JS分割字符串并放入数组的函数
2011/07/04 Javascript
JS中Iframe之间传值的方法
2013/03/11 Javascript
使用 Node.js 做 Function Test实现方法
2013/10/25 Javascript
浅析IE10兼容性问题(frameset的cols属性)
2014/01/03 Javascript
jquery读写cookie操作实例分析
2015/12/24 Javascript
快速掌握jQuery插件开发
2017/01/19 Javascript
js的OOP继承实现(必看篇)
2017/02/18 Javascript
微信小程序 本地图片按照屏幕尺寸处理
2017/08/04 Javascript
JavaScript文件的同步和异步加载的实现代码
2017/08/19 Javascript
JavaScript实现带有子菜单和控件的slider轮播图效果
2017/11/01 Javascript
React Navigation 使用中遇到的问题小结
2018/05/08 Javascript
angular2路由之routerLinkActive指令【推荐】
2018/05/30 Javascript
小程序如何使用分包加载的实现方法
2019/05/22 Javascript
vue仿ios列表左划删除
2019/09/26 Javascript
Vue数据双向绑定原理实例解析
2020/05/15 Javascript
python 解析XML python模块xml.dom解析xml实例代码
2014/02/07 Python
python的类变量和成员变量用法实例教程
2014/08/25 Python
给Python入门者的一些编程建议
2015/06/15 Python
python操作 hbase 数据的方法
2016/12/18 Python
Python编程实现控制cmd命令行显示颜色的方法示例
2017/08/14 Python
python 实现将字典dict、列表list中的中文正常显示方法
2018/07/06 Python
详解【python】str与json类型转换
2019/04/29 Python
Python 实用技巧之利用Shell通配符做字符串匹配
2019/08/23 Python
Python和Anaconda和Pycharm安装教程图文详解
2020/02/04 Python
Python如何爬取51cto数据并存入MySQL
2020/08/25 Python
Python Selenium XPath根据文本内容查找元素的方法
2020/12/07 Python
在C语言中实现抽象数据类型什么方法最好
2014/06/26 面试题
家长会主持词
2014/03/26 职场文书
新学期国旗下演讲稿
2014/05/08 职场文书
阳光体育运动标语口号
2015/12/26 职场文书
ubuntu20.04虚拟机无法上网的问题及解决
2022/12/24 Servers