jquery之Document元素选择器篇


Posted in Javascript onAugust 14, 2008

1.从$开始  
对于熟悉prototype的朋友,$符号应该很熟悉,   

prototype: var element = $('eleId')
jquery: var element = $('#eleId')
DOM: var element = document.getElementById('eleId')
以上三种选择方式是等价的,相比prototype来说jquery多了个#号
例:

$('#j1′).html()

<div id=“j1“>Hello, jQuery!</content>

2.通过xpath+css来获取你想要的…
   1).
在这段例子中我们需要用到的HTML代码 

<div class=”contentToChange”>
    <p class=”alert”>警告!警告!警告!警告!</p>
    <p class=”firstParagraph”>我是第一段</p>
    <p class=”secondParagraph”>第二段,哎,火箭输球了 0比33!火箭替补钉上耻辱柱 <em>姚麦</em>身边再无可用之人频繁失误成姚明致命毒药 板凳消失是火箭落后主因</p>
</div>
jquery代码: 

//获取div.contentToChange下p标记数组长度
  alert($('div.contentToChange p').size()) 

//通过调整高度来显示/隐藏所有匹配的元素,这里的匹配元素是p.firstParagraph
  $('div.contentToChange p.firstParagraph').slideToggle('slow');

//找到匹配所有div.contentToChange下所有css不为alert的p元素,并在其后面添加文字  
  $('div.contentToChange p:not(.alert)').append('<strong class=“addText“>这是新加的文字</strong>‘);

//找到所有为strong元素且css为addText的元素,然后删除
  $('strong.addText').remove();

//找到P标记下css为secondParagraph的元素,然后渐隐
  $('div.contentToChange p.secondParagraph').hide('slow');

//找到div.contentToChange下所有em元素,然后通过jquery中的css方法改变它们的颜色和字体
  $('div.contentToChange em').css({color:“#993300“,fontWeight:“bold“});

//添加css样式
  $('div.contentToChange p.secondParagraph').addClass('new‘)

//删除css样式
  $('div.contentToChange p.secondParagraph').removeClass('new‘);

   2).

在这段例子中我们需要用到的HTML代码:
<div id=”jqdt” style=”width: 400px; padding: 1em; border: 1px solid #000″>
 <p class=”goofy”> 这个 <em>段落</em> 包括了一些css属性为”groof”的 <strong>文本</strong>, 它还具有一个 <a href=”http://www.englishrules.com” class=”external text” title=”http://www.englishrules.com”>外部连接</a>, 一些 <code>$(代码)</code>, 和一个超连接属性是以 <a href=”#dt-link3_same-page_link” title=”">#打头的超连接</a>. </p>
 <ol>
  <li>list item 1 with dummy link to <a href=”/action/edit/Silly.pdf” class=”new” title=”Silly.pdf”>silly.pdf</a></li>
  <li class=”groof”><em>list <strong>item</strong> 2</em> with class=”<strong>groof</strong>“</li>
  <li>list item 3<span style=”display: none;”> SURPRISE!</span></li>
  <li><strong>list item 4</strong> with silly link to <a href=”/action/edit/Silly.pdf_silly.pdf” class=”new” title=”Silly.pdf silly.pdf”>silly.pdf silly.pdf</a></li>
  <li><a href=”contains.php”>支持火箭</a>,支持MM!</li>
 </ol>
</div>
jquery代码

//获取第一个list item
$('#jqdt ol li:eq(0)')
//等价于
$('#jqdt').find('li:eq(0)') //以下同

//获取所有偶数行的list item
$('#jqdt ol li:even')

//获取索引小于3的list item
$('#jqdt ol li:lt(3)')

//获取所有li中css不为groof的list item
$('#jqdt ol li:not(.groof)')

//获取P标记下所有超连接属性值以'#'打头的元素
$('p a[@href*=#]')

//获取所有code元素和css为groof的li元素的集合
$('#jqdt code, li.groof')

//先获取ol下css属性为groof的A, 然后找到节点A下的一级子节点strong元素
$('#jqdt ol .groof > strong')

//首先找到所有以list item作为自己的前一节点的list item元素(所以不会选择到第一个list item,因为它的前面没有list item节点了).然后在这些元素中找到超连接属性值以为'pdf'结尾的一级子节点
$('#jqdt ol li + li > a[@href$=pdf]')

//找到所有已隐藏的span元素
$('span:visible')

//找到超连接中包含火箭字样的元素
$('li a:contains(“火箭“)')

 
注:
$('#jqdt ol.groof > strong') 其中的>代表只访问下一级子节点中包含strong的元素,
如果改为 $('#jqdt ol.groof strong') 则访问所有下级子节点中的strong元素,包括子节点的子节点等。 

 3).
常用的自定义选择器
  :eq(0) 选择索引等于0也就是第一个元素

  :gt(4) 选择所有索引大于4的元素
  :lt(4) 选择所有索引小于4的元素
  :first 等价于 :eq(0) 
  :last 选择最后一个元素
  :parent 选择所有含有子节点的元素 (including text). 
  :contains('test') 选择含有指定文本的元素 
  :visible 选择所有可见元素(包含:display:block|inline,或者visibility为visible的元素,但是不包括表单元素(type hidden)
  :hidden 选择所有隐藏元素(包含:display:none,或者visibility为hidden的元素,包括表单元素(type hidden) 

例:

$('p:first').css('fontWeight','bold')
   $('div:hidden').show();
   $(“div:contains('test')“).hide();

   $('input[@name=bar]').val() //获取名字为bar的input表单的值
   $('select[@name=slt]').val() //获取名为slt的下拉菜单的选择中值
   $('input[@type=radio][@checked]') //获取所有被选中的radio表单

 
表单选择器 

  :input Selects all form elements (input, select, textarea, button). 
  :text Selects all text fields (type=”text”). 
  :password Selects all password fields (type=”password”). 
  :radio Selects all radio fields (type=”radio”). 
  :checkbox Selects all checkbox fields (type=”checkbox”). 
  :submit Selects all submit buttons (type=”submit”). 
  :image Selects all form images (type=”image”). 
  :reset Selects all reset buttons (type=”reset”). 
  :button Selects all other buttons (type=”button”). 

例:

  $('myForm:input')
  $('input:radio',myForm)
  //:radio等价于[@type=radio]

Javascript 相关文章推荐
关于Blog顶部的滚动导航条代码
Sep 25 Javascript
js有序数组的连接问题
Oct 01 Javascript
FireBug 调试JS入门教程 如何调试JS
Dec 23 Javascript
使用js操作css实现js改变背景图片示例
Mar 10 Javascript
简介EasyUI datagrid editor combogrid搜索框的实现
Apr 01 Javascript
Three.js利用Detector.js插件如何实现兼容性检测详解
Sep 26 Javascript
Popup弹出框添加数据实现方法
Oct 27 Javascript
基于BootStrap的文本编辑器组件Summernote
Oct 27 Javascript
记一次vue-webpack项目优化实践详解
Feb 17 Javascript
Node.JS用纯JavaScript生成图片或滑块式验证码功能
Sep 12 Javascript
Vue data的数据响应式到底是如何实现的
Feb 11 Javascript
如何用JavaScript检测当前浏览器是无头浏览器
Apr 27 Javascript
JavaScript国旗变换效果代码
Aug 13 #Javascript
js活用事件触发对象动作
Aug 10 #Javascript
JS支持带x身份证号码验证函数
Aug 10 #Javascript
js获取div高度的代码
Aug 09 #Javascript
js可突破windows弹退效果代码
Aug 09 #Javascript
ext form 表单提交数据的方法小结
Aug 08 #Javascript
ext实现完整的登录代码
Aug 08 #Javascript
You might like
PHP中$this和$that指针使用实例
2015/01/06 PHP
详解php中curl返回false的解决办法
2019/03/18 PHP
PHP7 windows支持
2021/03/09 PHP
[原创]js与自动伸缩图片 自动缩小图片的多浏览器兼容的方法总结
2007/03/12 Javascript
用javascript getComputedStyle获取和设置style的原理
2008/10/10 Javascript
说说JSON和JSONP 也许你会豁然开朗
2012/09/02 Javascript
浅析document.createDocumentFragment()与js效率
2013/07/08 Javascript
JS实现同时搜索百度和必应的方法
2015/01/27 Javascript
javascript 使用for循环时该注意的问题-附问题总结
2015/08/19 Javascript
使用NodeJs 开发微信公众号(三)微信事件交互实例
2016/03/02 NodeJs
BootStrap Validator 版本差异问题导致的submitHandler失效问题的解决方法
2016/12/01 Javascript
Angular-Touch库用法示例
2016/12/22 Javascript
详解Chai.js断言库API中文文档
2018/01/31 Javascript
jQuery zTree插件快速实现目录树
2019/08/16 jQuery
微信小程序自定义顶部组件customHeader的示例代码
2020/06/03 Javascript
Webpack的Loader和Plugin的区别
2020/11/09 Javascript
Python下使用Psyco模块优化运行速度
2015/04/05 Python
python清除字符串前后空格函数的方法
2018/10/21 Python
对pandas的算术运算和数据对齐实例详解
2018/12/22 Python
git查看、创建、删除、本地、远程分支方法详解
2020/02/18 Python
Python依赖包迁移到断网环境操作
2020/07/13 Python
详解pycharm2020.1.1专业版安装指南(推荐)
2020/08/07 Python
详解python定时简单爬取网页新闻存入数据库并发送邮件
2020/11/27 Python
python 使用paramiko模块进行封装,远程操作linux主机的示例代码
2020/12/03 Python
Python 实现PS滤镜中的径向模糊特效
2020/12/03 Python
Python使用paramiko连接远程服务器执行Shell命令的实现
2021/03/04 Python
Linux如何压缩可执行文件
2013/10/21 面试题
乡镇民主生活会发言材料
2014/10/20 职场文书
校本研修个人总结
2015/02/28 职场文书
土建技术员岗位职责
2015/04/11 职场文书
失恋33天观后感
2015/06/11 职场文书
2015秋季幼儿园开学通知
2015/07/16 职场文书
2015年小学远程教育工作总结
2015/07/28 职场文书
公司新员工欢迎词
2015/09/30 职场文书
PHP命令行与定时任务
2021/04/01 PHP
JavaScript小技巧带你提升你的代码技能
2021/09/15 Javascript