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 相关文章推荐
prototype 的说明 js类
Sep 07 Javascript
比较详细的关于javascript 解析json的代码
Dec 16 Javascript
使用js正则控制input标签只允许输入的值
Jul 29 Javascript
$.get获取一个文件的内容示例代码
Sep 11 Javascript
jquery制作图片时钟特效
Mar 30 Javascript
详解Bootstrap创建表单的三种格式(一)
Jan 04 Javascript
JavaScript实现精美个性导航栏筋斗云效果
Oct 29 Javascript
jQuery实现form表单序列化转换为json对象功能示例
May 23 jQuery
koa2实现登录注册功能的示例代码
Dec 03 Javascript
JS async 函数的含义和用法实例总结
Apr 08 Javascript
解决idea开发遇到javascript动态添加html元素时中文乱码的问题
Sep 29 Javascript
JS时间戳与日期格式互相转换的简单方法示例
Jan 30 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
从网上搜到的phpwind 0day的代码
2006/12/07 PHP
使用 MySQL 开始 PHP 会话
2006/12/21 PHP
PHP cdata 处理(详细介绍)
2013/07/05 PHP
php实现图片文件与下载文件防盗链的方法
2014/11/03 PHP
php中ob_get_length缓冲与获取缓冲长度实例
2014/11/20 PHP
PHP实现C#山寨ArrayList的方法
2015/07/16 PHP
PHP概率计算函数汇总
2015/09/13 PHP
Zend Framework使用Zend_Loader组件动态加载文件和类用法详解
2016/12/09 PHP
php preg_match的匹配不同国家语言实例
2016/12/29 PHP
javascript对talbe进行动态添加、删除、验证实现代码
2012/03/29 Javascript
jquery用data方法获取某个元素上的事件
2014/06/23 Javascript
jQuery随机密码生成的方法
2015/03/09 Javascript
Bootstrap模态框水平垂直居中与增加拖拽功能
2016/11/09 Javascript
javascript深拷贝的原理与实现方法分析
2017/04/10 Javascript
jQuery+pjax简单示例汇总
2017/04/21 jQuery
解决vue项目打包后提示图片文件路径错误的问题
2018/07/04 Javascript
vue实现图片上传到后台
2020/06/29 Javascript
Vant+postcss-pxtorem 实现浏览器适配功能
2021/02/05 Javascript
python 写入csv乱码问题解决方法
2016/10/23 Python
使用python生成杨辉三角形的示例代码
2018/08/29 Python
详解利用django中间件django.middleware.csrf.CsrfViewMiddleware防止csrf攻击
2018/10/09 Python
python Selenium实现付费音乐批量下载的实现方法
2019/01/24 Python
Python修改文件往指定行插入内容的实例
2019/01/30 Python
python接口自动化(十六)--参数关联接口后传(详解)
2019/04/16 Python
Python类中的装饰器在当前类中的声明与调用详解
2020/04/15 Python
Backcountry旗下的户外商品闪购网站:steep&cheap
2016/09/22 全球购物
荷兰本土平价百货:HEMA
2017/10/23 全球购物
Nike香港官网:Nike HK
2019/03/23 全球购物
Subside Sports德国:足球球衣和球迷商品
2019/06/08 全球购物
JAVA代码查错题
2014/10/10 面试题
艺术应用与设计个人的自我评价
2013/11/23 职场文书
开学寄语大全
2014/04/08 职场文书
会计求职自荐信
2014/06/20 职场文书
Redis做数据持久化的解决方案及底层原理
2021/07/15 Redis
Python echarts实现数据可视化实例详解
2022/03/03 Python
Python时间操作之pytz模块使用详解
2022/06/14 Python