日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 编程语言 > c/c++ >内容正文

c/c++

Ext Js MVC系列二 利用Application和Viewport进行应用程序初始化和页面布局

發(fā)布時(shí)間:2025/4/16 c/c++ 44 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Ext Js MVC系列二 利用Application和Viewport进行应用程序初始化和页面布局 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

通過(guò)上一篇我們已經(jīng)對(duì)Ext js MVC框架開(kāi)發(fā)有了一個(gè)大概的了解,這一篇將利用Application和Viewport進(jìn)行應(yīng)用程序的初始化和頁(yè)面布局。我想從以下幾方面來(lái)進(jìn)行總結(jié)。

1,通過(guò)Ext.Loader開(kāi)啟動(dòng)態(tài)加載功能
2,利用Application對(duì)象創(chuàng)建應(yīng)用程序?qū)嵗?br />3,利用Viewport和view進(jìn)行頁(yè)面布局

通過(guò)Ext.Loader開(kāi)啟動(dòng)態(tài)加載功能

通過(guò)Loader對(duì)象我們可以開(kāi)啟動(dòng)態(tài)加載的依賴加載功能,我們一般通過(guò)它的setConfig方法開(kāi)啟動(dòng)態(tài)加載,通過(guò)setPath設(shè)置加載路徑,然后通過(guò)Ext.require方法加載相關(guān)類庫(kù)。代碼如下。

/** 開(kāi)啟動(dòng)態(tài)加載的依賴加載功能和設(shè)置插件的路徑,并加載相關(guān)類庫(kù) **/ Ext.Loader.setConfig({ enabled: true });//開(kāi)啟動(dòng)態(tài)加載的依賴加載功能,默認(rèn)為false不開(kāi)啟 Ext.Loader.setPath('Ext.ux', '/Scripts/ux');//設(shè)置命名空間"Ext.ux"的路徑 Ext.require(['Ext.ux.CheckColumn', //加載相關(guān)類庫(kù)和它的直接依賴'Ext.ux.grid.FiltersFeature','Ext.ux.RowExpander','Ext.ux.grid.SPrint']);

利用Application對(duì)象創(chuàng)建應(yīng)用程序?qū)嵗?/h2>

通過(guò)Application對(duì)象我們可以創(chuàng)建應(yīng)用程序的實(shí)例,作為應(yīng)用程序的單一入口。在Application中我們可以設(shè)置全局命名空間,應(yīng)用程序路徑,是否開(kāi)啟自動(dòng)創(chuàng)建視口,和加載相關(guān)controller。代碼如下。

/** 創(chuàng)建應(yīng)用程序的實(shí)例 **/ Ext.application({name: 'MyExt', //設(shè)定應(yīng)用程序的命名空間(它將是controller,view.model和store的命名空間)appFolder: 'app', //設(shè)定應(yīng)用程序的路徑autoCreateViewport: true,//開(kāi)啟自動(dòng)創(chuàng)建Viewport,它將自動(dòng)去view目錄下查找Viewport文件并實(shí)例化controllers: [ //加載應(yīng)用程序所用到的所有controller'UserController'] });

利用Viewport和view進(jìn)行頁(yè)面布局

一個(gè)頁(yè)面只能有一個(gè)Viewport,它就像骨架一樣承載著多個(gè)view(這里指的上,下,左,右的panel),它是應(yīng)用程序界面的載體。下面是創(chuàng)建Viewport視口的代碼。

/*** *自定義一個(gè)Viewport類繼承Ext.container.Viewport ***/Ext.define('MyExt.view.Viewport', {extend: 'Ext.container.Viewport',alias: 'widget.viewport',//在實(shí)例化前加載相關(guān)類,一定要先加載,否則在構(gòu)造函數(shù)initComponent中無(wú)法使用 requires: ['MyExt.view.main.Top','MyExt.view.main.Bottom','MyExt.view.main.Left','MyExt.view.main.Content'],layout: 'border',//構(gòu)造函數(shù)initComponent: function () {var me = this;Ext.applyIf(me,{//將上,下,左,右四個(gè)面板作為獨(dú)立的view進(jìn)行實(shí)例化,然后作為item給Viewport items: [Ext.create('MyExt.view.main.Top'),Ext.create('MyExt.view.main.Bottom'),Ext.create('MyExt.view.main.Left'),Ext.create('MyExt.view.main.Content')]});me.callParent(arguments); //確保父類Ext.container.Viewport的構(gòu)造函數(shù)能被調(diào)用 } });

這個(gè)是Top面板的代碼,其它三個(gè)面板都是一樣,作為一個(gè)獨(dú)立的view,需要的時(shí)候再實(shí)例化,這樣就達(dá)到了view復(fù)用的目的。

/*** *自定義一個(gè)Panel類繼承Ext.Panel ***/ Ext.define('MyExt.view.main.Top', {extend: 'Ext.Panel',alias: 'widget.top',initComponent: function () {var me = this;Ext.apply(this, {region: 'north',title: 'top',height: 100,layout:'border',html:'this is north panel'});me.callParent(arguments);} });

Bottom面板

/*** *自定義一個(gè)Panel類繼承Ext.Panel ***/ Ext.define('MyExt.view.main.Bottom', {extend: 'Ext.Panel',alias: 'widget.bottom',initComponent: function () {var me = this;Ext.apply(this, {region: 'south',title: 'south',height: 100,layout: 'border',html: 'this is south panel'});me.callParent(arguments);} });

Left面板

/*** *自定義一個(gè)Panel類繼承Ext.Panel ***/ Ext.define('MyExt.view.main.Left', {extend: 'Ext.Panel',alias: 'widget.left',initComponent: function () {var me = this;Ext.apply(this, {region: 'west',title: 'west',width: 200,layout: 'border',html: 'this is west panel'});me.callParent(arguments);} });

Content面板

/*** *自定義一個(gè)Panel類繼承Ext.Panel ***/ Ext.define('MyExt.view.main.Content', {extend: 'Ext.Panel',alias: 'widget.content',initComponent: function () {var me = this;Ext.apply(this, {region: 'center',title:'center',layout: 'fit',html: 'this is center panel'});me.callParent(arguments);} });

運(yùn)行效果如圖。

這樣頁(yè)面的布局就算完成了,這里我們已經(jīng)對(duì)view有一個(gè)初步的認(rèn)識(shí),它其實(shí)就是利用窗體控件panel,grid或form等進(jìn)行用戶界面展示,我們最好將每一個(gè)view都定義成一個(gè)獨(dú)立的類,這樣需要使用的時(shí)候去實(shí)例化就好了,這樣達(dá)到了view復(fù)用的目的。下一篇我將總結(jié)如何利用view,store和model創(chuàng)建組件和數(shù)據(jù)交互。

轉(zhuǎn)載于:https://www.cnblogs.com/mcgrady/archive/2013/06/05/3119982.html

總結(jié)

以上是生活随笔為你收集整理的Ext Js MVC系列二 利用Application和Viewport进行应用程序初始化和页面布局的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 老司机深夜影院 | av网站观看 | 亚洲视频中文字幕在线观看 | 高清国产一区 | 日韩在线视频一区二区三区 | 狠狠躁夜夜躁人 | 伦av综合一区 | 伊人久久伊人 | 日韩综合一区 | 久久av无码精品人妻系列试探 | 日韩精品电影在线 | 国产精品2区| 91色视频在线 | 久久精品视 | 中文字幕9 | 91av视频播放 | 日韩av中文字幕在线播放 | 上原亚衣在线观看 | 一级高清视频 | 日韩中文字幕高清 | 超清纯大学生白嫩啪啪 | 男女啪啪免费看 | 亚洲国产精品视频在线观看 | 日韩精品无码一区二区三区久久久 | 国产欧美日韩综合精品 | 亚洲欧美日韩国产综合 | 久久久久久久久综合 | 乱码av| 在线观看久草 | 色一情 | 日韩免费高清视频网站 | 无码人妻一区二区三区在线 | 91少妇丨porny丨 | 91精品国产综合久久久蜜臀 | 原来神马电影免费高清完整版动漫 | 成人免费黄色大片 | 91日本视频 | 日韩成人高清 | 日韩视频在线观看 | 妇女一级片 | 成人久久免费视频 | 两性午夜视频 | 日韩av免费看 | 网站免费在线观看 | 欧美日韩色| 红桃视频国产精品 | 美女张开腿让男人操 | 台湾佬中文字幕 | 欧美老熟妇一区二区三区 | 国产精品久久久久久久久久东京 | 欧美日韩综合在线观看 | 天天干干干干干 | 三级a做爰全过程 | 国产一级二级在线 | 六月婷婷七月丁香 | 在线观看无码精品 | 午夜天堂影院 | 亚洲第一成人在线 | 日韩无码精品一区二区三区 | 极品91尤物被啪到呻吟喷水 | 中文av一区| 涩涩涩在线视频 | 欧美视频网址 | 中国黄色在线视频 | 欧美18一19性内谢 | av中文在线资源 | 少妇特殊按摩高潮惨叫无码 | 日韩精品在线免费视频 | 97麻豆视频| 国产黄色精品网站 | 人人干av| 久久精品69| 极品熟妇大蝴蝶20p 国产偷自拍视频 | 亚洲AV无码阿娇国产精品 | 男人干女人视频 | 好吊视频一区二区三区四区 | 无码成人精品区一级毛片 | 亚洲精品一区二区三区四区 | 国产精品啪啪啪视频 | 午夜黄色福利视频 | 喷水视频在线观看 | 加勒比hezyo黑人专区 | 深爱激情久久 | 欧美特黄一级视频 | 成人免费观看a | 欧美亚洲精品一区二区 | 日韩在线一二 | 99久久视频| 成人免费在线网址 | 99久久久无码国产 | 久久艳片www.17c.com | 久久日本视频 | 国产人妻精品一区二区三区不卡 | 最新亚洲精品 | 国产精品白嫩白嫩大学美女 | 黄色操人视频 | 亚洲欧洲无码一区二区三区 | 日本十八禁视频无遮挡 | 97超碰站 |