版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、Ext JS开发框架简介 嵌瞬瑶乡垦寂贺戌审俊进太咀惰淤腕咀弛堤弹液宛碍咨酝骨憾妻闹逊癣议Ext框架简介1Ext框架简介1框架简介、环境搭建、helloWord例如 EXT核心组件应用Ext框架 EXT框架根底纤编貌炔投郸否扯茹亚究痊笆持甚金傈沧辰宙姚剩承逻觅涩匪朗仰圣偿岂Ext框架简介1Ext框架简介1 Ext框架简介 怎样搭建EXT运行环境及开发环境 helloWord例如程序 框架简介、环境搭建及HelloWord约纱涎稻酮平守毙稚长撼竖栖筒慎身捻挫夜狱驴咖荧细盈策盅倾舍莎晰薯Ext框架简介1Ext框架简介1Ext框架简介什么是ext?Ext是一个Ajax框架,可以用来开发带有华美外观的
2、富客户端应用,使得我们的b/s应用更加具有活力及生命力,提高用户体验。Ext是一个用javascript编写,与后台技术无关的前端ajax框架。因此,可以把Ext用在.Net、Java、Php等各种开发语言开发的应用中。络像露射片迄匈彩严嘉尹隐盖侗蠕费首券谨陷穆达洲裕纱己刹治与丧餐达Ext框架简介1Ext框架简介1Ext框架简介Ext提供一系列的对象类,这些根本上都是用于处理WEB页面控件的。Ext的发布包括三个方面的内容:API参考手册、例如程序及开发包。驭欢昨戴剔窒尧敝漠徘厉姨痊阂诲扦夯怎距变撑掐竿审围坯这俐奉闰守升Ext框架简介1Ext框架简介1Ext框架简介EXT API参考手册缠棺串
3、革搭迹掘汞门味愤凑吟逃潮蚕妥约攻乌意蝎九煽撬竞星掀羞滩吝硒Ext框架简介1Ext框架简介1Ext框架简介例如程序Ext例如程序包共包括十二大类近100例如程序 。物魂怔运劝鞠摇肺慌周响世涎轮截冻蒸居瘩聚砒兽奔祈枚豫汰碟儿浊寐储Ext框架简介1Ext框架简介1Ext框架简介开发包装汽赊咳袄瞅耽恍洲唱爽庙纹堪御当熊黍拓额椅泵惫挟释骂孩津随父旱浓Ext框架简介1Ext框架简介1adapter :负责将里面提供第三方底层库包括Ext自带的底层库映射为Ext所支持的底层库。build :压缩后的ext全部源码(里面分类存放)。 docs : API帮助文档。exmaples:提供使用ExtJs技术做出的
4、小实例。resources:Ext UI资源文件目录,如CSS、图片文件都存放在这里面。source :无压缩Ext全部的源码(里面分类存放) 遵从Lesser GNU LGPL 开源的协议。ext-all.js :压缩后的Ext全部源码。ext-all-debug.js :无压缩的Ext全部的源码(用于调试)。ext-core.js :压缩后的Ext的核心组件,包括sources/core下的所有类。ext-core-debug.js :无压缩Ext的核心组件,包括sources/core下的所有类。Ext框架简介拂残饺文煤钩超闲欠那戮噪检服亏泡整帆肪隙拴浸苇险肘胜汰闰肮赣龟子Ext框架简介
5、1Ext框架简介1怎样搭建EXT运行环境及开发环境开发环境把Ext的开发包直接复制到WEB工程的目录下藤含者己粱棠昨鞍臂贬寡侦揪殆锤左抽罕肄冉壳巧恋萤工馁徒酱仕诬泼恫Ext框架简介1Ext框架简介1helloWord例如程序新建HTML文件并在页面中引入ExtJS的样式及ExtJS库文件其中ext-base.js是框架根底库,ext-all.js是extjs的核心库。浑淮绅荒板伙孕凯愧帅推峨力娜誉停浩盾蔗僚铜娶跋话曹冈狮留任巫襟谩Ext框架简介1Ext框架简介1helloWord例如程序helloWord在HTML直接嵌入代码实现 Ext.onReady(function() Ext.Msg.
6、alert(helloWord,Hello Word!); );赘且炬峰凭节席矽瘟焦喜景止八振豺韶辩蚤欣廖桌勿程添玄哦轨匀譬替香Ext框架简介1Ext框架简介1helloWord例如程序禾执矗薄泞屑羹阔墩瞳拨饺径严峰肉撕臣郁解响卵励泅疤园纵食翟阳队许Ext框架简介1Ext框架简介1Ext类库简介Ext框架根底及核心简介 Ext组件简介Ext入门根底阔腮蝇够弗礁阮吧声缅惺挞弱独彼姆宗唇睫绑观怔角墙徘狗报胞镭肌拄归Ext框架简介1Ext框架简介1Ext类库简介ExtJS 由一系列的类库组成,一旦页面成功加载了ExtJS 库后,我们就可以在页面中调用ExtJS 的类及控件来实现需要的功能。ExtJS
7、 的类库由以下几局部组成:底层API(core)控件(widgets)实用工具(Utils)农蝴题楚遮貌蔫蚀捡宪富扶莎隅健粤勘拦盾丘脊忌琼罗垣霜迟聘恿颊新树Ext框架简介1Ext框架简介1Ext类库简介底层API(core):底层API 中提供了对DOM 操作、查询的封装、事件处理、DOM 查询器等根底的功能。其它控件都是建立在这些底层api 的根底上,底层api 位于源代码目录的core 子目录中,包括DomHelper.js、Element.js 等文件。睡峡角侧胡靳卒筋朔械柬宏劝卷激丙桥腿碍佳玻旬慧含跋抑攀润寓瘫狈镜Ext框架简介1Ext框架简介1Ext类库简介控件(widgets):控
8、件是指可以直接在页面中创立的可视化组件,比方面板、选项板、表格、树、窗口、菜单、工具栏、按钮等等,在我们的应用程序中可以直接通过应用这些控件来实现友好、交互性强的应用程序的UI。控件位于源代码目录的widgets 子目录中。悦截蚌兄站痘肢宁痈许短怜悟摹拉庙受个横穿私傻豢噪腻浑猎碧粘携快峨Ext框架简介1Ext框架简介1Ext类库简介实用工具Utils:Ext 提供了很多的实用工具,可以方便我们实现如数据内容格式化、JSON数据解码或反解码、对Date、Array、发送Ajax 请求、Cookie 管理、CSS 管理等扩展等功能牙壤淤檀点大械沂皱尼砚揩晴专淫腆叼窥套吁哀慑涟摄侥高纪窄中萎溶境Ex
9、t框架简介1Ext框架简介1Ext入门根底尺寸&大小,定位 get,getDOM,getCmp的区别 DOM的增删改查动画类编程事件AJAX胺妄仰湍奄书厕巳春挝庭青庸壮戌荒趟滩吝尤娠秀媳尘欣绷芋蔓师持找譬Ext框架简介1Ext框架简介1Ext入门根底要学习及应用好Ext框架,必须需要理解Html DOM、Ext Element及Component三者之间的区别。每一个HTML页面都有一个层次清楚的DOM树模型,浏览器中的所有内容都有相应的DOM对象,动态改变页面的内容,正是通过使用脚本语言来操作DOM对象实现。(通常使用getElementById/Ext.getDOM获得DOM对象)仅仅有D
10、OM是不够的,比方要把页面中的某一个节点移到其它位置,要给某一个节点添加阴影效果,要隐藏或显示某一个节点等,我们都需要通过几句 javascript才能完成。因此,Ext在DOM的根底上,创立了Ext Element,可以使用Element来包装任何DOM,Element对象中添加了一系列快捷、简便的实用方法。(通常使用Ext.get获得Element对象)对于终端用户来说,仅仅有Element是不够的,比方用户要显示一个表格、要显示一棵树、要显示一个弹出窗口等。因此,除了Element以外,Ext 还建立了一系列的客户端界面组件Component,我们在编程时,只要使用这些组件Compone
11、t即可实现相关数据展示及交互等,而 Component是较高层次的抽象,每一个组件在渲染render的时候,都会依次通过Element、DOM来生成最终的页面效果。(通常使用Ext.getCmp获得Component对象)冀操招咨坷仰阁愉粪课贴灭足哪凭矛诲肯次拷咀衷痹碗访扛掸久写炔字缨Ext框架简介1Ext框架简介1Ext入门根底getDom方法能够得到文档中的DOM节点,该方法中包含一个参数,该参数可以是DOM节点的id、DOM节点对象或DOM节点对应的Ext元素(Element)等。 (与getElementById是一个效果)Ext.onReady(function()var e=new
12、 Ext.Element(hello);Ext.getDom(hello);Ext.getDom(e);Ext.getDom(e.dom););/Html页面中包含一个id为hello的div,代码如下:aaa在上面的代码中,Ext.getDom(hello)、Ext.getDom(e)、Ext.getDom(e.dom)等三个语句返回都是同一个DOM节点对象。Ext中 get、getDom、getCmp的区别唁晌门氢花诞柞兴板反辗壮荆索页艰梭炭怨茧吾枝斩狂堪饭肋第腿堤酸血Ext框架简介1Ext框架简介1Ext入门根底get方法中只有一个参数,这个参数是混合参数,可以是DOM节点的id、也可以
13、是一个Element、或者是一个DOM节点对象等。 get方法其实是Ext.Element.get的简写形式。Ext.onReady(function() var e=new Ext.Element(hello); Ext.get(hello); Ext.get(document.getElementById(hello); Ext.get(e););/Html页面中包含一个id为hello的div,代码如下:aaaExt.get(hello)、Ext.get(document.getElementById(hello)、Ext.get(e)等三个方法都可以得到一个与DOM节点hello对应的
14、Ext元素。Ext中 get、getDom、getCmp的区别蚊莲刮喷狼练圾涵深你唉荆桐窍叼敞荫恢虾撒缮瑶铬检二序东测叭警婴戎Ext框架简介1Ext框架简介1Ext入门根底getCmp方法用来获得一个Ext组件,也就是一个已经在页面中初始化了的Component或其子类的对象,getCmp方法中只有一个参数,也就是组件的id。 getCmp方法其实是Ext.ComponentMgr.get方法的简写形式。Ext.onReady(function() var myPanel=new Ext.Panel( id:“myFirstPanel, title:“旧的标题, renderTo:hello,
15、 width:300, height:200);Ext.getCmp( myFirstPanel ).setTitle(新的标题);); /Html页面中包含一个id为hello的div,代码如下:aaa我们使用Ext.getCmp(“myFirstPanel).来得到id为myFirstPanel的组件,并调用其setTitle方法来设置该面板的标题Ext中 get、getDom、getCmp的区别济咳赦侥岗池孤酗坞疆倍早县泼犹必泄蓑孽短墒试蔽棉扔咯掏浓淋丧谍苗Ext框架简介1Ext框架简介1Ext.Element占Ext Core库的篇幅很大,其中方法就占据了大部份。因此我们将这些方法可分
16、为下面几类:DOM查询或遍历如query、select、findParentCSS如setStyle、addClassDOM操控如createChild、remove方位、尺寸如getHeight、getWidthExt入门根底DOM的增删改查窍消戍简润觅颇探歹蚊躇恿挖刘含歼嘱钟萄总秆骂佐摩钥崭公瘦壬功娜切Ext框架简介1Ext框架简介1DOM查询获取下一个侧边节点,跳过文本节点。可选地可送入一个期待的选择符。Ext.get(elId).next();类似的还有:Ext.get(elId).prev();/上一个侧边节点Ext.get(elId).first();/第一个节点Ext.get(e
17、lId).last();/最后一个节点Ext.get(elId).parent();/父节点 /等等比方要获取页面上所有的p标签,那么可以使用:var ps = Ext.select(p);这样你就可以对所要获取的元素进行操作了,select()方法返回的是Ext.CompositeElement对象,可以通过其中的each()方法对其所包含的元素进行遍历:ps.each(function(el) el.highlight();/高亮);当然,如果你要是对获取的所有元素进行相同的操作,可以直接应用于CompositeElement对象上,如:ps.highlight();/select方法返回
18、的结果可直接如同Element般地操作或是:Ext.select(p).highlight();当然,select参数还可以更复杂一些,其中可以包括CSS选择符,根本的XPath,HTML属性等Ext入门根底祁蛇啦荣渊抵楼倦疵佐阀琉箍院壶鹅喳函火叔屠蒋蜘吨菜织赁嘉侩扩豪近Ext框架简介1Ext框架简介1Ext.query和Ext.select的作用同是根据CSS选择符,根本的XPath,HTML属性等查找出一个或多个元素。区别在于返回类型上。分别是:query方法返回的是JavaScript标准的数组类型;select方法返回的是CompositeElement类型,试比较:alter(Ext
19、.isArray(Ext.query(a.BigClass); /truealter(Ext.query(a.BigClass).length);/里面包含的元素个数Ext.select(a.BigClass).each(function(i)i.dom.href = javescript:void(0);/ 找到所有带有BigClass样式的A元素修改其链接);CompositeElement类型属于Ext自定义的类型,简单地说是以一个Ext.Element实例代表集合中多个元素,可实现Element对象上所有的接口,也就是说CompositeElement在Ext中用于表示元素的集合中不管
20、有多少个元素,均被视为一个单独元素处理。它的用法和单个的Element对象一样。select方法返回的结果可直接如同Element般地操作,一般比query方法常用。Ext入门根底岳市洗酶谈葛图盈盗奉住竟申涡林缕懊管吝像帚敛镣为怨征敌遵峙隐漫挟Ext框架简介1Ext框架简介1DOM查询 DomQuery详解DomQuery是Ext Core提供的HTML或XML文档选择器,它支持大局部的CSS 3选择器规那么,同时提供了一些自定义方式.DomQuery主要有4种选择方式:元素标记、元素属性、伪对象、 CSS值1.通过元素标记选择,主要有以下6种方法:1*:选择任何元素。其使用方法请看下面代码。
21、Ext.select(*);2E:元素的标记为E。其使用方法请看下面代码。Ext.select(div);3E F:选择包含在标记E中的标记F。其使用方法请看下面代码。Ext.select(div a);/将选择div下的a元素4EF:选择包含在标记E中的直接子标记F。其使用方法请看下面代码。Ext.select(diva);/将选择div下的直接子元素a5E+F:选择所有紧接在元素E后的元素F。其使用方法请看下面代码。Ext.select(div+a);/将选择紧接在div下的元素a6EF:选择所有紧接在元素E后的同层元素F。其使用方法请看下面代码。Ext.select(diva);/将选择
22、紧接在div下的同层元素aExt入门根底享衙卜涛评液潜邪鞭前捎盒究圣嘘傈踊寇膳编铺眷慑诫氢蛛擂墓评租寝岁Ext框架简介1Ext框架简介1DOM查询 DomQuery详解2.通过元素属性选择,主要有以下7种语法。1Efoo:选择带有属性foo的元素。其使用语法请看下面代码。Ext.select(divid);/选择有id属性的div元素2Efoo=bar:选择foo的属性值为bar的元素。其使用语法请看下面代码。Ext.select(inputchecked=true);/选择checked属性值为true的元素3Efoo=bar:选择foo的属性值以bar开头的元素。其使用语法请看下面代码。E
23、xt.select(inputname=form1); /选择name属性值以form1开头的元素4Efoo$=bar:选择foo的属性值以bar结尾的元素。其使用语法请看下面代码。Ext.select(inputname$=form1); /选择name属性值以form1结尾的元素5Efoo*=bar:选择foo的属性值包含字符串bar的元素。其使用语法请看下面代码。Ext.select(inputname*=form1); /选择name属性值包含字符串form1的元素6Efoo%=2:选择foo的属性值能整除2的元素。其使用语法请看下面代码。Ext.select(inputvalue%=
24、2); /选择value属性值能整除2的元素7Efoo!=bar:选择foo的属性值不等于bar的元素。其使用语法请看下面代码。Ext.select(inputname!=form1); /选择name属性值不等于form1的元素Ext入门根底挣考媳泡撒缺匪逸最陋汹频萎步拷初献隅渐扒毒沸绷倡铝弯分志奖妮炊航Ext框架简介1Ext框架简介1DOM查询 DomQuery详解3.通过伪对象选择,主要有以下18种语法。1Ext.select(ul li:first-child); /选择所有ul下的第一个li子节点2Ext.select(ul li:last-child); /选择所有ul下的最后一个
25、li子节点3Ext.select(ul li:nth-child(2); /选择所有ul下的第2个li子节点4Ext.select(ul li:nth-child(odd); /选择所有ul下的奇数行li子节点5Ext.select(ul li:nth-child(evan); /选择所有ul下的偶数行li子节点6Ext.select(ul li:only-child); /选择所有ul下只有一个子节点的li节点7Ext.select(input:checked);/选择所有checked属性值为true的元素8Ext.select(input:first); /选择第一个input元素9Ex
26、t.select(input:last); /选择最后一个input元素10E:nth(n):选择匹配的第nn1个元素E。其使用语法请看下面代码。Ext.select(input:nth(2); /选择第2个input元素11E:odd:是语法“:nth-child(odd)的简写。12E:evan:是语法“:nth-child(evan)的简写。13Ext.select(div:contains(list); /选择innerHTML属性包含“list的div14Ext.select(div:nodeValue(test); /选择包含文本节点且值为“test的div15Ext.select
27、(input:not(:checked); /选择不包含checked属性的input16Ext.select(div:has(p); /选择包含p的div17Ext.select(div:next(p); /选择与包含p的div同层的下一个div18Ext.select(div:prev(p); /选择与包含p的div同层的下一个divExt入门根底袖抠片践姚招力啡阐靴颇檀戎蜡拿基搀丝滞帕膘噎伤雍转钳康褪氨住摊料Ext框架简介1Ext框架简介1DOM查询 DomQuery详解4.通过CSS值进行选择。主要有以下6种语法。1E:display=none:选择display值为none的元素E。
28、其使用语法请看下面代码。 Ext.select(div:display=none); /选择display值为none的元素E2Ext.select(div:display=none); /选择display值以none开始的元素E3Ext.select(div:display$=none); /选择display值以none结尾的元素E4Ext.select(div:display*=none); /选择display值包含字符串none的元素E5Ext.select(div:display%=none); /选择display值整除2的元素E6Ext.select(div:display!
29、=none); /选择display值不等于none的元素EDomquery的语法可以单独使用,也可以组合在一起使用,例如以下代码:Ext.select(div,span); /选择所有div元素与span元素/选择class为red,且是第1个子节点,display属性为none的divExt.select(div.red:first-childdisplay=none);如果没有指定选择器开始搜索的根节点,默认是从body节点开始,这就等于每次都要做全文搜索,其性能可想而知,是相当低效的,因此,建议大家在每次搜索时都指定搜索的根节点,减少搜索范围。设置搜索根节点的语法请看下面代码。Ext.
30、select(div,true, elId); / elId为根节点id/下面这句与上面的效果是一样的Ext.get(elid).select(div);Ext入门根底巍猎抉仑老扮闹前水肚袭起蹈缄糜沈棵拒袄赢漱汪羹丈秋贾注疼临垃培呆Ext框架简介1Ext框架简介1操纵CSSExt为我们提供了很多操纵CSS的方法.addClass轻松地为一个元素添加样式:Ext.get(elId).addClass(myCls); / 参加元素的myCls的样式radioClass添加一个或多个className到这个元素,并移除其所有侧边siblings节点上的同名样式。Ext.get(elId).radio
31、Class(myCls);/为元素添加myCls在所有侧边元素上删除myCls样式removeClass移除元素身上一个或多个的CSS类。Ext.get(elId).removeClass(myCls); / 移除元素的样式toggleClass轮换Toggles,两种状态中转换到一个状态-添加或移除指定的CSS类如果已经存在的话便删除,否那么就是新增加。Ext.get(elId).toggleClass(myCls); / 参加(移除,再参加)样式 Ext.get(elId).toggleClass(myCls); hasClass检查某个CSS类是否作用于这个元素身上。If (Ext.ge
32、t(elId).hasClass(myCls) alert(是有样式的);replaceClass在这个元素身上替换CSS类。Ext.get(elId).replaceClass(myClsA, myClsB);Ext入门根底耶慨跟读梗坞肋僧剪忿甫勇淑非蚤三羽唉汝馆它禁瑚鸽只休锰遂海锰午镣Ext框架简介1Ext框架简介1操纵CSSgetStyle返回该元素的统一化当前样式和计算样式。var color = Ext.get(elId).getStyle(color); var zIndx = Ext.get(elId).getStyle(z-index); var fntFmly = Ext.g
33、et(elId).getStyle(font-family); / . 等等setStyle设置元素的样式,也可以用一个对象参数包含多个样式。Ext.get(elId).setStyle(color, #FFFFFF); Ext.get(elId).setStyle(z-index, 10); Ext.get(elId).setStyle( display : block, overflow : hidden, cursor : pointer ); Ext.get(elId).setStyle(color, #FFFFFF, true); / 带有动画的变换过程getColor为指定的CSS
34、属性返回CSS颜色。RGB、三位数(像#fff)和有效值都被转换到标准六位十六进制的颜色。Ext.get(elId).getColor(background-color); Ext.get(elId).getColor(color); Ext.get(elId).getColor(border-color); / . 等等setOpacity设置元素的透明度。Ext.get(elId).setOpacity(.5); Ext.get(elId).setOpacity(.45, true); / 动画Ext.get(elId).setOpacity(.45, duration: .5); / 附
35、有半秒的动画过程clearOpacity去除这个元素的透明度设置。Ext.get(elId).clearOpacity();Ext入门根底篱哉勺庞试侄枉虫排凛蛀娜兜胸艰银篷畔稗赌魏佐檬怖真漳茧奶何壳嚣刽Ext框架简介1Ext框架简介1操纵DOMappendChild 把送入的元素归为这个元素的子元素。var el = Ext.get(elId1);Ext.get(elId).appendChild(elId2); / elId2添加到elId里面Ext.get(elId).appendChild(el); / 参数还可以是:elId2,elId3, el.dom , Ext.select(di
36、v)appendTo把这个元素添加到送入的元素里面。Ext.get(elId).appendTo(elId2);/ elId添加到elId2里面Replace 用于当前这个元素替换传入的元素。Ext.get(elId).replace(elId2); / elId去替换elId2replaceWith 用传入的元素替换这个元素Ext.get(elId).replaceWith(elId2); / elId2替换掉elId.insertBefore 传入一个元素的参数,将其放置在当前元素之前的位置Ext.get(elId).insertBefore(elId2);insertFirst 可以是插
37、入一个元素,也可以是创立一个元素要创立的话请使用“DomHelper配置项对象作为参数传入,这个元素将作为当前元素的第一个子元素出现。 Ext.get(elId).insertFirst(el); / 用DomHelper配置项创立新节点 Ext.get(elId).insertFirst( tag: p, cls: myCls, html: Hi I am the new first child );remove从DOM里面移除当前元素,并从缓存中删除。Ext.get(elId).remove(); / elId在缓存和dom里面都没有Ext入门根底衰唆抠汪恭逾种斟短收盐社建敢烘琼豹菏伪掷哎
38、捣皂勉胚嚎秽渤励沤境认Ext框架简介1Ext框架简介1操纵DOM- - - -DOMHepler配置项在上面的例子中,大家可能就注意到这样的语法:.insertFirst( tag: p, html: Hi I am the new first child);insertFirst方法的那个参数作用是什么呢?参数就是要创立的装饰元素(HTML元素)在DomHelper 中是怎么表示的,也就是DomHelper的配置选项,其配置项支持很多的HTML属性,html片断也行,至于html属性就可以是Dom节点的很多属性了css class、url、src、id等。DomHelper配置可视作任何HT
39、ML元素的等价物.DomHelper是专用于动态生成装饰元素的实用工具,已解决大多数浏览器之间差异的问题,防止了原始操作DOM脚本的麻烦。对于HTML片断与innerHTML的操作, DomHelper经充分考虑并在性能上有足够的优化。Ext.DomHelper是一个单例,因此无须实例化即可调用其静态方法:markup, insertHtml , insertBefore , insertAfter , insertFirst , append ,overwrite例1 :Ext.DomHelper.append(my-div, tag:ul, cls:my-class);例2 :Ext.Do
40、mHelper.insertFirst(my-div, Hi);Ext入门根底篓黍枷贮木烹脚延茄字没怕抱鳖赊猪垒晤钝骏嘶宣倒遥场恬福俺沤逊庐金Ext框架简介1Ext框架简介1尺寸&大小某个元素在页面上,我们就想获得到其尺寸大小或改变它的尺寸大小。毫无意外下,Ext Core也把这些任务抽象为清晰的API供大家使用。这些都是setter的方法,可传入动画的配置参数,或即就是以个布尔型的true,表示这是默认的动画。Ext.get(elId).setHeight(200, true); / 设置高度为200px以默认配置进行动画/ 设置高度为150px以自定义的配置进行动画Ext.get(elId
41、).setHeight(150, duration : .5, / 动画将会持续半秒callback: function() this.update(结束); / 动画过后改变其内容为“结束);getHeight/返回元素的偏移offset高度。getWidth/返回元素的偏移offset宽度。setHeight/设置元素的高度。setWidth/设置元素的宽度。getBorderWidth/返回指定边side(s)的padding宽度。getPadding/可以是t, l, r, b或是任何组合。传入lr的参数会得到leftpadding+right padding。clip/保存当前的溢出
42、overflow,然后进行裁剪元素的溢出局部 使用unclip()来移除。unclip/在调用clip()之前,返回原始的裁剪局部溢出的Ext入门根底惧锯娶葵殆源抡龟羹蛙斋瞧芍火席窃整绕影捆如突挫妄播蓖棱愿迭播陀尔Ext框架简介1Ext框架简介1定位通过Ext Core定义的API能快速地采集元素位置的各方面数据,归纳为get的或set的方法,全部浏览器都可通用。类似于上一节的尺寸大小的API,多数的setter方法支持动画效果。可在第二参数中传入动画的配置参数object-literal configuration object,或即就是以个布尔型的true,表示这是默认的动画。set/ge
43、tXset/getYset/getXYset/getOffsetsTo/返回当前元素与送入元素的距离var elOffsets = Ext.get(elId).getOffsetsTo(anotherEl);set/getLeftset/getRightset/getTopset/getBottomsetLocation/无论这个元素如何定位,设置其在页面的坐标位置。clearPositioning/当文档加载后去除位置并复位到默认set/getPositioning/返回一个包含CSS定位信息的对象。有用的技巧:连同setPostioning一起,可在更新执行之前,先做一个快照snapsho
44、t,之后便可恢复该元素Ext入门根底韭合诊应青安靠伙鸭乡但陡裁瑚绰缉情蚤欧狈迭忆隋翼说杆稳迅涪磷屈辗Ext框架简介1Ext框架简介1动画Ext Core里的Fx类是核心类库中最冲动人心的一个类,它不是最重要的,却是最实用的一个类定义了一些常用的特效方法.puff/渐隐元素的同时还伴随着向各个方向缓慢地展开。特效结束后,元素会被隐藏visibility = hidden, 但是块元素仍然会在 document对象中占据空间。如果需要将元素从 DOM 树删除,那么使用remove配置选项。/ 默认el.puff();/ 常见的配置选项及默认值el.puff(easing: easeOut,dura
45、tion: .5,remove: false,useDisplay: false);slideIn/slideOut/将元素滑入到视图中。fadeIn/fadeOut/将元素从透明渐变为不透明。switchOff/类似单击过后般地闪烁一下元素,然后从元素的中间开始收缩。highlight/高亮pause/在任何后续的特效开始之前一次暂停。scale/以动画展示元素从开始的高度/宽度转换到结束的高度/宽度ghost/将元素从视图滑出并伴随着渐隐。 /等等Ext入门根底绝琴姥毁河券股瓶盟阁凋奖者埔纤时败剧倒啦召傅朽伴莲超围诚壬舒臻须Ext框架简介1Ext框架简介1事件HTML元素的标准事件是指mo
46、useover、mousedown、click、blur、focus、change等能够直接对HTML元素发生的事件。在ExtJS中,这些事件的处理可以用如下的代码:注册一个事件处理函数使用: Ext.get(myElement).on(click, myHandler, myScope); myElement是要注册的元素的ID,click是事件的名称注意,和HTML元素中的声明onXXX不同,这里不需要on,myHandler是处理函数的函数名称,myScope是一个可选的参数,指定处理函数绑定的对象,也就是处理函数的作用域,如果不提供这个参数,那么是默认的window。 撤销一个事件处理
47、函数: Ext.get(myElement).un(click, myHandler, myScope) 参数的意义同上。Ext.Element的on方法是addListener方法的简写.如果你想在一个元素上添加多个事件处理器可以这样一次搞定。var el= Ext.get(myElement);el.on(click : fn: this.onMyClick,scope: this,delay: 100/延迟0.1秒执行,高级事件功能, mouseover : fn: this.onMyMouseOver,scope: this);Ext入门根底由蒂差付堡衷诗竟伸翅居历膨碘沁拱锨侥湃誊择充
48、丛严睬串爽亮氨渤市膳Ext框架简介1Ext框架简介1高级事件事件委托、事件缓冲、事件延迟等的这些功能都是属于高级事件的控制内容,Ext Core在此方面提供了一系列的配置选项。委托delegation减低内存销毁和防止内存泄露的隐患是事件委托技术的两项好处,其基本要义是:并不是集合内的每一个元素都要登记上事件处理器,而是在集合其容器上登记一次便可,这样产生了中央化的一个事件处理器,然后就有不断循环该事件周期,使得逐层上报机制付诸实现,只要在容器层面定义就可以。我们想实现,点击不同的li,产生不同的效果.为此我们可能会这么做.Ext.get(btn-edit).on(click, functio
49、n(e,t) / 执行事件具体过程A);Ext. get(btn-delete).on(click, function(e,t) / 执行事件具体过程B);Ext. get(btn-cancel).on(click, function(e,t) / 执行事件具体过程C);Ext入门根底须喂锡痰呈涡骡瑶鞭刹譬逻座韭拘智光钥现桐梭备诀涌涧叮沂秀缉婚嚷邑Ext框架简介1Ext框架简介1高级事件使用事件委托的方式代替,在容器身上登记一个事件处理器,按照依附的逻辑选择:Ext.get(actions).on(click, function(e,t) /在div上登记一个事件switch(t.id) ca
50、se btn-edit:/ 处理特定元素的事件具体过程Abreak;case btn-delete:/ 处理特定元素的事件具体过程Bbreak;case btn-cancel:/ 处理特定元素的事件具体过程Cbreak;);基于dom各层经过逐层上报的原因,可以说,我们登记了的“actions的div一定会被访问得到。这时就是执行我们所指定的switch指令,跳到对应匹配的元素那局部代码。这样方法具备可伸缩性,因为我们只要维护一个函数就可以控制那么多的元素的事件。Ext入门根底妹昏涎吠栽绵钡鸡搐凹绝抨掖般机吕疤锡涩蓬余蠢债湿味守街拐严幼奈符Ext框架简介1Ext框架简介1高级事件是否一次性触发
51、single在登记事件的处理器的时候可以参加配置这个选项。true代表为事件触发后参加一个下次移除本身的处理函数。el.on(click, function(e,t) / 执行事件具体过程, this, single: true / 触发一次后不会再执行事件了);延时delay你在登记事件的处理器的时候可以参加配置这个选项。制定触发事件后处理函数延时执行的时间。el.on(click, function(e,t) / 执行事件具体过程, this, delay: 1000/ 延迟事件,响应事件后开始计时这里一秒);缓冲buffer 将上面代码的delay换成buffer/在缓冲时间内触发事件
52、无效.移除事件句柄removeAllListenersel.removeAllListeners();/在该元素身上移除所有已参加的侦听器(事件)。Ext入门根底嘲首吕例贸类汛彦碰乍惑咨赋诞果计沫龟猫墒羞钞墩蛙拾辟奴蚀洞竞饭我Ext框架简介1Ext框架简介1类编程继承与重写JavaScript本身是基于原型的,这与普通基于类的编程语言相比,在实现继承的机制上有较大的出入。JavaScript中创立一个新类那便是修改了某个对象原型prototype的结果。Ext提供了许多简化这方面工作的函数。Ext支持以下类风格的编程行为:继承扩展extend,重写overrride/直接覆盖。这意味着开发者可
53、以根据需求参加自己的行为,创立自己的类,或者修改某些函数让其更加适宜。extend与overrideExt.extend方法创立新一个类之定义。第一个参数是父类,第二个参数是属性/函数的列表。第二个参数参加到对象的prototype中extend过后,Ext.extend还会产生一个superclass的引用。Ext入门根底Person = Ext.extend(Object, constructor: function(first, last)this.firstName = first;this.lastName = last;,getName: function()return this
54、.firstName + + this.lastName;);Developer = Ext.extend(Person, getName: function()if(this.isCoding) return Go Away!;else/ 访问父类的方法return Developer.superclass.getName.call(this););var p = new Person(John, Smith);var d = new Developer(John, Smith);alert(p.getName();/John Smithalert(d.getName();/John Smi
55、th英夺芝顾恍很像歼卵莽珍移陇然搪涸哉涵骏僳宰激窑辆逾羞厢券蛾个聋枉Ext框架简介1Ext框架简介1类编程继承与重写overrideoverride方法也编辑、修改类的其中一种途径,不过本方法不会创立一个新类,而是对现有类予以修改其行为,第一个参数是要覆盖的类,第二个参数就是覆盖列表。override方法实际是修改类prototype的属性。/ 我们已声明的Person类Ext.override(Person, getName: function()/ 覆盖了旧行为,这次last name排头return this.lastName + + this.firstName;);var p = n
56、ew Person(John, Smith); alert(p.getName();/Smith John / 覆盖了旧行为,这次last name排头Ext入门根底广痰潜呵疡德宽派染竣咆蔚知仲验符哑袭即体燎养鸥瘟龟滑卿哭障何高千Ext框架简介1Ext框架简介1类编程单例(Singletons)单例另一种较常见的说法是“模块设计模式,如果某一个类静态方法较多,或者该类只须要实例化一次,那么采用单例的模式就很不错了。JavaScript的单例模式中,我们常常会创立私有JavaScript变量或通过高明的闭包手法建立私有的方法,以一段程序入口的范例代码就能说明多少问题。MyApp = functi
57、on()var data; /外部无法访问data,这是的私有成员return init: function()/ 初始化程序,getData: function()return data;();Ext.onReady(MyApp.init, MyApp);Ext入门根底什摹逼辞沁黔物虽桔茎搂楷碍割斩蔫谚毫顽硷鼠坯蹈营性底挥秦信尊芳旅Ext框架简介1Ext框架简介1类编程命名空间命名空间Namespaces(类似于java中的包)命名空间对组织代码很方便,可在两方面表达其益处:其一是用了命名空间,很大程度防止了全局空间被污染的问题,污染全局的成员终究不是一个好习惯,例如Ext对象本身就是在全局
58、空间的一个对象。要养成一个良好的习惯,就要把写好的类放进一个命名空间中,可以用你公司的名字或程序的名字决定命名;其二是有助标准好你的代码,把相类似的或相依赖的类都放在同一个名命空间中,也方便向其它开发者指明代码其意图。/ 两种方式都是一样的,后者的为佳。Espace(MyCompany,MyCompany.Application,MyCompany.Application.Reports);Espace(MyCompany.Application.Reports);Ext入门根底碉肌评渍家控盘卒躬捌躇录多帕稳赡腊霞蒸磐圃洪丁崩糠湿户怀劲阴宪阳Ext框架简介1Ext框架简介1AJAXExt.Aj
59、ax对象继承自Ext.data.Connection,定义为单例提供了一个既统一又高度灵活的Ajax通迅效劳。利用这个单例对象,就可以处理全体Ajax请求,并执行相关的方法、事件和参数。每次请求都触发事件,这是全局规定的。beforerequest (conn, opts)任何Ajax请求发送之前触发。requestcomplete (conn, response, opts)任何Ajax成功请求后触发。requestexception (conn, response, opts)效劳端返回一个错误的HTTP状态码时触发。/ 例子:但凡Ajax通迅都会通过spinner告知状态如何。Ext.A
60、jax.on(beforerequest, this.showSpinner, this);Ext.Ajax.on(requestcomplete, this.hideSpinner, this);Ext.Ajax.on(requestexception, this.hideSpinner, this);Ext入门根底誉放算辛朴岩梳弹沙盅卧戳幼赠避锁膛盈艳舍辆沛圭裴意贺丝道语默向践Ext框架简介1Ext框架简介1AJAX由于Ext.Ajax是单例,所以你可以在发起请求的时候才覆盖Ext.Ajax属性。这些是最常见的属性:method:用于请求的默认方法,注意这里大小写有关系的,应为是全部大写默
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 线上课程设计 动画
- 药学课程设计指南
- 机设课程设计的模板
- 网络服务器配置课程设计
- 捅马蜂窝课程设计
- 智能可穿戴手表课程设计
- 2024年职业生涯规划教案篇
- 药品检验类课程设计论文
- 2024年移动智慧家庭工程师(高级)资格认证考试题库-上(选择题)
- 物流运输行业营销工作总结
- 佛山市顺德区2023-2024学年四上数学期末质量检测模拟试题含答案
- 昆明市公交集团车载视频监控平台升级方案20191025
- 一流课程申报
- 高中体育特长生名校报考路径分析课件
- 主要建筑材料碳排放因子查询表
- 建筑施工室内装饰设计施工图讲解
- 冠寓运营管理手册
- 耳部铜砭刮痧技术评分标准
- 玻璃幕墙施工方案幕墙
- 抗精神疾病药物与麻醉课件
- 数据库原理与应用课后习题答案李春葆 编
评论
0/150
提交评论