昨天刚接触到Extjs,简单写了篇学习笔记,今天继续。

天介绍一下Ext中组件举几个简单的例子做说明。注意:文章内容有些摘自本人学习过程中看到的资料。

Ext2.0对框架进行了非常大的重构,其中最重要的是形成了一个结构及层次分明的组件体系,由这些组件形成了Ext控件。Ext组件由Component类定义,每一种组件都有一个指定的xtype属性值,通过该值可以得到一个组件的类型或者是定义一个指定类型的组件。

Ext组件体系由下图所示:

组件大致可分成三大类,即基本组件、工具栏组件、表单元素组件。

基本组件有

这么多的组件,可都是非常酷的。组件使用可以直接通过关键字new 来创建,比如上篇文章中说到的创建一个Window框

var win=new Ext.Window();

除了这种创建方式,一般都会在构造函数中加一些配置属性来初始化组件。比如创建一个面板:

function panel(){

var params={title:"Hello",width:300,height:200,html:"

一个面板

"};

var panel=new Ext.Panel(params);

panel.render("panel");

}


关键代码:

function panel(){

var params={title:"Hello",width:300,height:200,html:"

一个面板

"};

var panel=new Ext.Panel(params);

panel.render("panel");

}

params是设置Panle的参数,title:标题,width:宽度,height:高度,html:面板显示的内容

var panel=new Ext.Panel(params); 这句代码创建了一个面板,并在构造函数中设置了面板属性。

panel.render("panel"); 表示页面上的p元素id.、

代码可以简写为:

复制代码 代码如下:

var panel=new Ext.Panel({renderTo:"panel",title:"Hello",width:300,height:200,html:"

一个面板

"});

对于组件中的子元素组件,都支持延迟加载的方式创建控件,此时可以直接通过父容器的items传递数组方式实现。

function panel(){

var params={

title:"Hello",

width:300,

height:200,

html:"

一个面板

",

items:[

new Ext.Panel({title:"Panel1",height:100}),

new Ext.Panel({title:"Panel2",height:100})

]

};

var panel=new Ext.Panel(params);

panel.render("panel");

}

如果需要让组件显示出不同的效果,我们就需要通过构造函数中的参数设置。

由于组件都继承自Ext.Component,因此所有组件可能有共同的属性,如下图

Extjs提供了一套强大的事件处理机制,专门处理用户动作、监控控件状态、更新控件视图信息、与服务器交互等等。事件由Ext.EventManager对象管理,与浏览器W3C标准事件对象Event相对应,Ext封装了一个Ext.EventObject事件对象。支持事件处理的类(或为接口)为Ext.util.Observable,凡事继承该类的组件或类都支持往对象中添加时间处理及响应功能。

我们在页面上加一个按钮

在写一个函数

function eventtest(){

Ext.Msg.alert("提示","触发了一个事件!");

}

下面通过Ext的事件处理机制为btntest这个按钮添加一个点击事件,点击后调用eventtest方法。

Ext.onReady(

function(){

Ext.get("btntest").addListener("click",eventtest);

}

);

在Ext组件加载完毕后直接给按钮添加一个click事件。Ext.get("btntest").addListener(事件,事件执行方法,无需加括弧);

Ext还支持延迟事件处理缓存等功能,比如下面的代码:

Ext.get("btntest1").addListener("click",eventtest,this,{delay:2000});

Ext.get("btntest1").addListener("click",eventtest,this,{delay:2000});这句代码为按钮注册了一个click事件,但会延迟2000毫秒执行。

可以为html元素添加事件了,我们还可以控制Ext组件的事件,在看一个例子。

function eventwindow(){

var win=new Ext.Window({

title:"控制Ext组件的事件",

height:200,

width:300

});

win.on(

"beforedestroy",

function(obj){

Ext.Msg.alert("哈哈","你关不掉了吧!");

obj.show();

return false;

}

);

win.show();

}

每个组件都含有beforedestroy事件,Ext会在销毁这一组件时触发该事件。 这段代码会显示一个窗体,并且点击关闭按钮时会失效。通过Window的on方法来控制.. on(事件,事件执行函数).由于窗口对象的beforedestroy事件响应函数返回值为false,因此执行这段程序,窗体才无法关闭。组件的时间监听器也可以直接在构造函数中直接声明,下面的代码会和上面同一效果:

function eventwindow(){

var win=new Ext.Window({

title:"控制Ext组件的事件",

height:200,

width:300,

listeners:{

"beforedestroy":

function(obj){

Ext.Msg.alert("哈哈","你关不掉了吧!");

obj.show();

return false;

}

}

});

win.show();

}

效果如下:

OK,这就是Ext组件的介绍与使用。各位有什么问题可以留言一起讨论,有什么不对的地方请指正。

此文章中用的例子都只是简单介绍,后面会详细讲解。

本文原创发布php中文网,转载请注明出处,感谢您的尊重!

extlink.php,ExtJs 学习笔记基础篇 Ext组件的使用_extjs相关推荐

  1. MySQL学习笔记-基础篇1

    MySQL 学习笔记–基础篇1 目录 MySQL 学习笔记--基础篇1 1. 数据库概述与MySQL安装 1.1 数据库概述 1.1.1 为什么要使用数据库 1.2 数据库与数据库管理系统 1.2.1 ...

  2. Redis学习笔记①基础篇_Redis快速入门

    若文章内容或图片失效,请留言反馈.部分素材来自网络,若不小心影响到您的利益,请联系博主删除. 资料链接:https://pan.baidu.com/s/1189u6u4icQYHg_9_7ovWmA( ...

  3. MySQL学习笔记-基础篇2

    MySQL学习笔记-基础篇2 目录 MySQL学习笔记-基础篇2 8.子查询 8.1 需求分析与问题解决 8.1.1 实际问题 8.1.2 子查询的基本使用 8.1.3 子查询的分类 8.2 单行子查 ...

  4. python3多线程编程_Python 3多线程编程学习笔记-基础篇

    本文是学习<Python核心编程>的学习笔记,介绍了Python中的全局解释器锁和常用的两个线程模块:thread, threading,并对比他们的优缺点和给出简单的列子. 全局解释器锁 ...

  5. C++ 学习笔记----基础篇

    (一)类和抽象数据类型   1.通过类实现的接口(公有和私有)可实现信息隐藏.实现对数据的封装等: 2.抽象数据类型(ADT:Abstract Data Type):当一个数据类型仅暴露公有接口,而将 ...

  6. java学习笔记-基础篇

    Java基础篇 1-12 常识 13 this关键字 14参数传递 16 继承 17 访问权限 28-31异常 1-12 常识 1.文件夹以列表展示,显示扩展名,在地址栏显示全路径 2.javac编译 ...

  7. 易语言学习笔记——基础篇

    易语言学习笔记20180710 一. 易语言的数据类型可以分为基本数据类型和特殊数据类型 1.     其中基本数据类型分为: ①   数值型 ②   逻辑型 ③   日期时间型 ④   文本型 ⑤  ...

  8. 渗透学习笔记--基础篇--sql注入(数字型)

    环境:dvwa 1.7数据库:mysql dvwa的安全等级:medium 一.分析和查找注入点 (1)知识点回顾 如果上一篇有好好读过的同学应该知道,我们上一篇遇到的字符型注入.也即是通过Get或者 ...

  9. 扇贝编程python无法退款_扇贝编程python学习笔记-基础篇1

    我要成为一个勤奋努力上进的人 第一关 学习用时:15min 随堂测验+上机作业:10min 随堂作业正确率:4/5 1.尝试执行代码 import random menu = ['粉丝', '炒饭', ...

最新文章

  1. Paddle Detection
  2. 在Java8的foreach()中不能break,如果需要continue时,可以使用return
  3. .Net 程序员走向高端必读书单汇总
  4. hihocoder-Week173--A Game
  5. svn在linux下的使用(svn命令行)ubuntu 删除 新增 添加 提交 状态查询 恢复
  6. pycharm 显示空格及tab
  7. 《JavaScript权威指南》笔记(四)
  8. ArcGIS学习总结(12)——拓扑检查和修正
  9. chattr 锁定文件
  10. 狂神Docker视频学习笔记(基础篇)
  11. 【云计算学习教程】云应用是什么?典型的云应用有哪些?
  12. matlab maps 指北针和比例尺,R 地图绘制-比例尺与指北针
  13. Arm V8内存管理架构.学习笔记
  14. 迅雷下载 HP QTP LR QC AML MyEclipse8.5 Tomcat7地址
  15. 引力模型-高维固定效应面板泊松模型
  16. Python Pyinstaller安装与使用
  17. 想让人瞬间死心只能豁出去把自己和一种恶心的东西连接在一起,一旦生理反抗达成。想不死心也不行。
  18. m4r格式转换器免费版 V3.0
  19. 5问法:找出问题的根本原因
  20. 浪潮服务器 raid 系统引导,浪潮服务器RAID配置及系统引导.doc

热门文章

  1. N900 Dual boot(meego maemo)
  2. ASP程序快速生成Excel文件
  3. MyEclipse8.5/8.6不能安装ADT
  4. linux 提权方法总结
  5. golang 文件操作 创建 读写 复制移动 权限 删除
  6. java rmi 原理和使用浅析
  7. python3 selenium 无头浏览器 错误 FileNotFoundError: [Errno 2] No such file or directory: 'geckodriver'
  8. linux free 命令 显示内存使用情况
  9. 多目录cmake工程 CmakeLists.txt编写
  10. golang 面向对象编程