• ExtJS2.0实用简明教程 组件的使用


            组件可以直接通过new 关键子来创建,比如控件一个窗口,使用new Ext.Window(),创建一个表格则使用new Ext.GridPanel()。当然,除了一些普通的组件以外,一般都会在构造函数中通过传递构造参数来创建组件。

            组件的构造函数中一般都可以包含一个对象,这个对象包含创建组件所需要的配置属性及值,组件根据构造函数中的参数属性值来初始化组件。比如下面的例子:
    <script>
    var obj={title:"hello",300,height:200,html:'<h1>Hello,easyjf open source</h1>'};
    var panel=new Ext.Panel(obj);
    panel.render("hello");
    </script>
    <div id="hello">&nbsp;</div>

      运行上面的代码可以实现如下图所示的结果:

      可以省掉变量obj,直接写成如下的形式:

    var panel=new Ext.Panel({title:"hello",300,height:200,html:'<h1>Hello,easyjf open source</h1>'});
    panel.render("hello");

      render方法后面的参数表示页面上的div元素id,也可以直接在参数中通过renderTo参数来省略手动谳用render方法,只需要在构造函数的参数中添加一个renderTo属性即可,如下:

    new Ext.Panel({renderTo:"hello",title:"hello",300,height:200,html:'<h1>Hello,easyjf open source</h1>'});

      对于容器中的子元素组件,都支持延迟加载的方式创建控件,此时可以直接通过在需要父组件的构造函数中,通过给属性items传递数组方式实现构造。如下面的代码: 

    var panel=new Ext.TabPanel({300,height:200,items:[
    {title:"面板1",height:30},{title:"面板2",height:30},{title:"面板3",height:30}]
    });
    panel.render("hello");

      注意中括号中加粗部份的代码,这些代码定义了TabPanel这个容器控件中的子元素,这里包括三个面板。上面的代码与下面的代码等价:

    var panel=new Ext.TabPanel({300,height:200,items:[new Ext.Panel(
    {title:"面板1",height:30}),new Ext.Panel({title:"面板2",height:30}),new Ext.Panel({title:"面板3",height:30})]
    });
    panel.render("hello");

      前者不但省略掉了new Ext.Panel这个构造函数,最重要前者只有在初始化TabPanel的时候,才会创建子面板,而第二种方式则在程序一开始就会创建子面板。也就是说,前者实现的延迟加载。

  • 相关阅读:
    动手开发自己的第一个 composer 包
    实现网易云视频直播播放器功能
    html文本标准模式,首行空两格,两端对齐,行高
    设置svg图片大小
    IntelliJ IDEA,代码行宽度超出限制时自动换行
    是什么时候开始学习gulp了
    Laravel 安装多国语言包后,phpstorm 还是报错
    解决Package illuminate/html is abandoned, you should avoid using it. Use laravelcollective/html instead.问题
    去掉悬浮框与点击框之间的线条问题
    解决实现注册功能点击注册的时候报错问题
  • 原文地址:https://www.cnblogs.com/licheng/p/1317306.html
Copyright © 2020-2023  润新知