时间:2021-07-01 10:21:17 帮助过:23人阅读
var elem = Ext.get('start');
elem.on('click', function(e, t) {
alert(t.id);
});
查询多个元素操作
代码如下:
var body = Ext.query('body')[0];
body.className = "myStyle";
在实际项目中,由于需要更改一类元素的信息提示样式,如果根据 css 来查找的话,当需要消失操作时,就不能继续根据 css 来查找所有的元素了。这时,同事教会了我一种新的方法,如下:
代码如下:
<span style='display:none;' group='message_group' class='error'></span>
<span style='display:none;' group='message_group' class='error'></span>
// 这样多个同样属于 group 下的元素,可以通过此种方式获取:
var elemMessageArray = Ext.select("span[group='message_group']");
var newCssObj = {};
if (isInfo) {
newCssObj["class"] = "info";
} else {
newCssObj["class"] = "error";
}
// 然后对每个元素重新设置css样式就行了
elemMessageArray.each( function(el) {
el.set(newCssObj);
el.update(text);
el.show("display");
});
元素的显示和隐藏
之前我一般用的方式
代码如下:
Uncompleted = Ext.get('uncompleted');
elemUncompleted.setDisplayed(true);
这种方式能够提供动画效果,但是这样的话,如果需要元素消失时:元素虽然消失了,但是同样还是会占用了元素的空间位置,不便布局。后来,同事发现可以采用这种方式,虽然没有了动画效果,但是不会占用元素的位置:
代码如下:
el.show("display");
el.hide("display");
刚才发现文档中的说明:
Hide this element - Uses display mode to determine whether to use "display" or "visibility". See setVisible.
仔细阅读文档是程序员必须要学会做的!