Ext.Component

对标签(尤指div)的封装

所有Ext组件的基类,组件下所有的子类都可能参与自动化Ext组件的生命周期执行创建, 渲染和销毁都是由Container容器类提供,组件可以通过容器配置items创建, 也可以通过动态方法 add创建

组件基类内置了组件的 隐藏/显示,启用/禁用,大小控制行为.

所有组件被注册在布局管理器中Ext.ComponentManager, 这样就可以通过Ext.getCmp随时被引用,

所有用户自定义的可视部件,他们的生命周期和规模 管理的子类组件都必须参加.

组件(component)通常不被实例化,因为有子类实现专门的组件. 很多时候覆盖了大部分的应用需求。 但是,它是可以实例化的基础组件,它会被渲染,或将参与一个容器的子项的布局

在页面中只创建Ext.Component

    Ext.create("Ext.Component", {
        renderTo: Ext.getBody()
    })

得到html标签

<div class="x-component  x-component-default x-border-box" id="box-1009"></div>

 

autoEl:值默认为 'div',可以改变整体标签的强大属性

       autoEl: {
            tag: 'img',
            src: 'http://www.example.com/example.jpg'
        }
<img class="x-component  x-component-default x-border-box" src="http://www.example.com/example.jpg" id="box-1009">

 

autoScroll:true-->overflow样式

<div class="x-component  x-component-default x-border-box" id="box-1009" style="overflow: auto;"></div>

 

baseCls:button-->基础css,配合bootstrap修改样式-->默认`x-component`

<div class="button  button-default x-border-box" id="box-1009"></div>

 

border:'10 5 3 10'-->好烦,只有width

<div class="x-component  x-component-default x-border-box" style="border-width:10px 5px 3px 10px;" id="box-1009"></div>

 

childEls:定义子元素的快捷入口,相当方便

Ext.create('Ext.Component', {
    renderTo: Ext.getBody(),
    renderTpl: [
        '<h1 id="{id}-title" data-ref="title">{title}</h1>',
         '<h1 id="{id}-test" data-ref="test">{testHtml}</h1>',
        '<p>{msg}</p>',
    ],
    renderData: {
        title: "Error",
        msg: "Something went wrong",
        testHtml:'testHtml.......'
    },
    childEls: ["title", { name: 'buttonText', itemId: 'test' },],
    listeners: {
        afterrender: function(cmp){
            console.log(cmp.title);
            console.log(cmp.buttonText);
            cmp.title.setStyle({color: "red"});
        }
    }
});

相对于extjs4.0,data-ref必须存在,作用暂时无视

 

cls :'text' -->$().addCss

<div class="x-component  text x-component-default x-border-box" id="box-1009"></div>

 

componentCls:业务区分cls,最后会加入cls的坑,没有就等于baseCls,不入坑

            if (me.componentCls) {
                cls.push(me.componentCls);
            } else {
                me.componentCls = me.baseCls;
            }

 

contentEl:通过id,使用html模版,而非手写,非常方便的东西,尽管ext宣称无视html-.-

最终会: contentEl = Ext.get(me.contentEl);

 

draggable:拖拽,对方法的封装,在html面看不见变化

 

html:innerHtml,属于html片段

 

posted on 2015-11-19 22:40  Glimis  阅读(447)  评论(0编辑  收藏  举报