Ext.get() 和 Ext.query()组合使用实现最灵活的取元素方式


Posted in Javascript onSeptember 26, 2011

前面写的get()和query()我都省略参数了,先看看文档中的函数原型:
Ext.get( Mixed el ) : Element
Parameters:
el : Mixed
The id of the node, a DOM Node or an existing Element.
Returns:
Element
The Element object
Ext.query( String path, [Node root] ) : Array
Parameters:
path : String
The selector/xpath query
root : Node
(optional) The start of the query (defaults to document).
Returns:
Array
query函数返回的其实是一个DOM Node的数组,而Ext.get的参数el可以是DOM Node,哈哈,明白了吗?就是说要实现最灵活的取法,应该用query取到DOM Node然后交给get去变成Element。也就是:
var x=Ext.query(QueryStr);
//我为什么不写成内联函数形式?因为这里的x只能是一个元素,而上面那句的x是一个Array,大家自己转换和处理吧
var y=Ext.get(x);
那么接下来需要介绍QueryStr的格式(其实和jQuery里的selector的格式很像啦),至于获得Element后可以干些啥,大家自己去看ExtJS文档里关于Ext.Element的说明,我就不摘过来了。
先给一个html代码,好做演示说明

<html> 
<body> 
<div id="bar" class="foo"> 
I'm a div ==> my id: bar, my class: foo 
<span class="bar">I'm a span within the div with a foo class</span> 
<a href="http://www.extjs.com" target="_blank">An ExtJs link</a> 
</div> 
<div id="foo" class="bar"> 
my id: foo, my class: bar 
<p>I'm a P tag within the foo div</p> 
<span class="bar">I'm a span within the div with a bar class</span> 
<a href="#">An internal link</a> 
</div> 
<div name="BlueLotus7">BlueLotus7@126.com</div> 
</body> 
</hmlt>

(1)根据标记取:// 这个查询会返回有两个元素的数组因为查询选中对整个文档的所有span标签。
Ext.query("span");
// 这个查询会返回有一个元素的数组因为查询顾及到了foo这个id。
Ext.query("span", "foo");// 这会返回有一个元素的数组,内容为div标签下的p标签
Ext.query("div p");
// 这会返回有两个元素的数组,内容为div标签下的span标签
Ext.query("div span");(2)根据ID取:// 这个查询会返回包含我们foo div一个元素的数组!
Ext.query("#foo"); //或者直接Ext.get("foo");(3)根据class的Name去取:Ext.query(".foo");// 这个查询会返回5个元素的数组。
Ext.query("*[class]"); // 结果: [body#ext-gen2.ext-gecko, div#bar.foo, span.bar, div#foo.bar, span.bar](4)万能法去取:(用这个方法可以通过id、name、class、css等取)// 这会得到class等于“bar”的所有元素
Ext.query("*[class=bar]");
// 这会得到class不等于“bar”的所有元素
Ext.query("*[class!=bar]");
// 这会得到class从“b”字头开始的所有元素
Ext.query("*[class^=b]");
//这会得到class由“r”结尾的所有元素
Ext.query("*[class$=r]");
//这会得到在class中抽出“a”字符的所有元素
Ext.query("*[class*=a]");//这会得到name等于“BlueLotus7”的所有元素
Ext.query("*[name=BlueLotus7]");
我们换个html代码:
<html> 
<head> 
</head> 
<body> 
<div id="bar" class="foo" style="color:red;"> 
我是一个div ==> 我的id是: bar, 我的class: foo 
<span class="bar" style="color:pink;">I'm a span within the div with a foo class</span> 
<a href="http://www.extjs.com" target="_blank" style="color:yellow;">An ExtJs link with a blank target!</a> 
</div> 
<div id="foo" class="bar" style="color:fushia;"> 
my id: foo, my class: bar 
<p>I'm a P tag within the foo div</p> 
<span class="bar" style="color:brown;">I'm a span within the div with a bar class</span> 
<a href="#" style="color:green;">An internal link</a> 
</div> 
</body> 
</html>

// 获取所以红色的元素
Ext.query("*{color=red}"); // [div#bar.foo]
// 获取所有粉红颜色的并且是有红色子元素的元素
Ext.query("*{color=red} *{color=pink}"); // [span.bar]
// 获取所有不是红色文字的元素
Ext.query("*{color!=red}"); // [html, head, script firebug.js, link, body#ext-gen2.ext-gecko, script ext-base.js, script ext-core.js, span.bar, a www.extjs.com, div#foo.bar, p, span.bar, a test.html#]
// 获取所有颜色属性是从“yel”开始的元素
Ext.query("*{color^=yel}"); // [a www.extjs.com]
// 获取所有颜色属性是以“ow”结束的元素
Ext.query("*{color$=ow}"); // [a www.extjs.com]
// 获取所有颜色属性包含“ow”字符的元素
Ext.query("*{color*=ow}"); // [a www.extjs.com, span.bar]
(5)伪操作符取法换个html:
<html> 
<head> 
</head> 
<body> 
<div id="bar" class="foo" style="color:red; border: 2px dotted red; margin:5px; padding:5px;"> 
我是一个div ==> 我的id是bar,我的class是foo 
<span class="bar" style="color:pink;">这里是span元素,外层的div元素有foo的class属性</span> 
<a href="http://www.extjs.com" target="_blank" style="color:yellow;">设置blank=target的ExtJS链接</a> 
</div> 
<div id="foo" class="bar" style="color:fushia; border: 2px dotted black; margin:5px; padding:5px;"> 
这里的id是:foo,这里的class是bar 
<p>“foo” div包围下的p元素。</p> 
<span class="bar" style="color:brown;">这里是一个span元素,外层是div包围着,span还有一个bar的class属性。</span> 
<a href="#" style="color:green;">内置链接</a> 
</div> 
<div style="border:2px dotted pink; margin:5px; padding:5px;"> 
<ul> 
<li>条目 #1</li> 
<li>条目 #2</li> 
<li>条目 #3</li> 
<li>条目 #4 带有<a href="#">链接</a></li> 
</ul> 
<table style="border:1px dotted black;"> 
<tr style="color:pink"> 
<td>第一行,第一列</td> 
<td>第一行,第二列</td> 
</tr> 
<tr style="color:brown"> 
<td colspan="2">第二行,已合并单元格!</td> 
</tr> 
<tr> 
<td>第三行,第一列</td> 
<td>第三行,第二列</td> 
</tr> 
</table> 
</div> 
<div style="border:2px dotted red; margin:5px; padding:5px;"> 
<form> 
<input id="chked" type="checkbox" checked/><label for="chked">已点击</label> 
<br /><br /> 
<input id="notChked" type="checkbox" /><label for="notChked">not me brotha!</label> 
</form> 
</div> 
</body> 
</html>

//SPAN元素为其父元素的第一个子元素
Ext.query("span:first-child"); // [span.bar]
//A元素为其父元素的最后一个子元素
Ext.query("a:last-child") // [a www.extjs.com, a test.html#]
//SPAN元素为其父元素的第2个子元素(由1开始的个数)
Ext.query("span:nth-child(2)") // [span.bar]
//TR元素为其父元素的奇数个数的子元素
Ext.query("tr:nth-child(odd)") // [tr, tr]
//LI元素为其父元素的奇数个数的子元素
Ext.query("li:nth-child(even)") // [li, li]
//返回A元素,A元素为其父元素的唯一子元素
Ext.query("a:only-child") // [a test.html#]
//返回所有选中的(checked)的INPUT元素
Ext.query("input:checked") // [input#chked on]
//返回第一个的TR元素
Ext.query("tr:first") // [tr]
//返回最后一个的INPUT元素
Ext.query("input:last") // [input#notChked on]
//返回第二个的TD元素
Ext.query("td:nth(2)") // [td]
//返回每一个包含“within”字符串的DIV
Ext.query("div:contains(within)") // [div#bar.foo, div#foo.bar]
//返回没有包含FORM子元素以外的那些DIV
Ext.query("div:not(form)") [div#bar.foo, div#foo.bar, div]
//返回包含有A元素的那些DIV集合
Ext.query("div:has(a)") // [div#bar.foo, div#foo.bar, div]
//返回接着会继续有TD的那些TD集合。尤其一个地方是,如果使用了colspan属性的TD便会忽略
Ext.query("td:next(td)") // [td, td]
//返回居前于INPUT元素的那些LABEL元素集合
Ext.query("label:prev(input)") //[label, label]
Javascript 相关文章推荐
Use Word to Search for Files
Jun 15 Javascript
jquery左右滚动焦点图banner图片鼠标经过显示上下页按钮
Oct 11 Javascript
jQuery/CSS3图片特效插件整理推荐
Dec 07 Javascript
jQuery学习笔记之jQuery中的$
Jan 19 Javascript
JavaScript的类型、值和变量小结
Jul 09 Javascript
AngularJS实现表单手动验证和表单自动验证
Dec 09 Javascript
详解javascript跨浏览器事件处理程序
Mar 27 Javascript
利用纯Vue.js构建Bootstrap组件
Nov 03 Javascript
JavaScript中setTimeout的那些事儿
Nov 14 Javascript
使用canvas实现一个vue弹幕组件功能
Nov 30 Javascript
手把手带你封装一个vue component第三方库
Feb 14 Javascript
vuex实现像调用模板方法一样调用Mutations方法
Nov 06 Javascript
一个挺有意思的Javascript小问题说明
Sep 26 #Javascript
Jquery之Ajax运用 学习运用篇
Sep 26 #Javascript
jQuery+CSS 实现随滚动条增减的汽水瓶中的液体效果
Sep 26 #Javascript
在Windows上安装Node.js模块的方法
Sep 25 #Javascript
javascript权威指南 学习笔记之null和undefined
Sep 25 #Javascript
利用JS自动打开页面上链接的实现代码
Sep 25 #Javascript
javascript权威指南 学习笔记之javascript数据类型
Sep 24 #Javascript
You might like
异世界新番又来了,同样是从零开始,男主的年龄降到5岁
2020/04/09 日漫
php之可变函数的实例详解
2017/09/13 PHP
PHP实现的CURL非阻塞调用类
2018/07/26 PHP
用Laravel Sms实现laravel短信验证码的发送的实现
2018/11/29 PHP
遍历jquery对象的代码分享
2011/11/02 Javascript
jQuery 淡出一个图像到另一个图像的实现代码
2013/06/12 Javascript
javascript删除字符串最后一个字符
2014/01/14 Javascript
javascript类型转换使用方法
2014/02/08 Javascript
基于jQuery实现仿百度首页换肤背景图片切换代码
2015/08/25 Javascript
JS中call/apply、arguments、undefined/null方法详解
2016/02/15 Javascript
利用Node.js+Koa框架实现前后端交互的方法
2017/02/27 Javascript
说说AngularJS中的$parse和$eval的用法
2017/09/14 Javascript
JavaScript中EventLoop介绍
2018/01/22 Javascript
Vue中props的使用详解
2018/06/15 Javascript
js事件on动态绑定数据,绑定多个事件的方法
2018/09/15 Javascript
js实现移动端吸顶效果
2020/01/08 Javascript
[01:51]开启你的城市传奇 完美世界城市挑战赛开始报名
2018/10/09 DOTA
python查询sqlite数据表的方法
2015/05/08 Python
django1.8使用表单上传文件的实现方法
2016/11/04 Python
Python中创建字典的几种方法总结(推荐)
2017/04/27 Python
使用Turtle画正螺旋线的方法
2017/09/22 Python
python 3.0 模拟用户登录功能并实现三次错误锁定
2017/11/01 Python
python日期时间转为字符串或者格式化输出的实例
2018/05/29 Python
python批量下载抖音视频
2019/06/17 Python
Pandas时间序列重采样(resample)方法中closed、label的作用详解
2019/12/10 Python
python pptx复制指定页的ppt教程
2020/02/14 Python
vue常用指令代码实例总结
2020/03/16 Python
PYQT5 vscode联合操作qtdesigner的方法
2020/03/24 Python
Python实现捕获异常发生的文件和具体行数
2020/04/25 Python
Matplotlib自定义坐标轴刻度的实现示例
2020/06/18 Python
详解python tcp编程
2020/08/24 Python
京东奢侈品:全球奢侈品牌
2018/03/17 全球购物
斯洛伐克香水和化妆品购物网站:Parfemy-Elnino.sk
2020/01/28 全球购物
违反校纪校规检讨书
2014/02/15 职场文书
安全生产活动月方案
2014/03/09 职场文书
中班下学期幼儿评语
2014/12/30 职场文书