<div class="iteye-blog-content-contain" style="font-size: 14px"></div>
ext4 新引用了require这个异步加载机制,但是我用require引用了俩个需要加载的子类的时候,不能通过create去实例化,请问各位大神有没有什么好的解决办法,代码如下 :
//(function(){ Ext.Loader.setConfig({ enabled : true, paths : { 'myApp' : 'js/myApp' //配置路径 } }); /*Ext.require('myApp.view.tree.tabPanels' // , 'myApp.view.tree.myTreePanelView' );*/ //var tabPanel=Ext.create('myApp.view.tree.tabPanels',{}); //var treePanelView=Ext.create('myApp.view.tree.myTreePanelView',{}); /* var tabPanel=Ext.create('js.testjs.commonjs.tabPanels',{ title:'this my new Panel' });*/ /*Ext.Loader.setPath('myApp', 'js/myApp'); Ext.require('myApp.view.tree.indexPage');*/ Ext.onReady(function() { Ext.QuickTips.init(); // NOTE: This is an example showing simple state management. During // development, // it is generally best to disable state management as dynamically-generated // ids // can change across page loads, leading to unpredictable results. The // developer // should ensure that stable state ids are set for stateful components in // real apps. Ext.state.Manager.setProvider(Ext.create('Ext.state.CookieProvider')); Ext.create('Ext.Viewport', { /*Ext.define('myApp.view.tree.indexPage',{ extend : 'Ext.Viewport',*/ uses : ['myApp.view.tree.myTreePanelView', 'myApp.view.tree.tabPanels'], id : 'border-example', layout : 'border', items : [ // create instance immediately Ext.create('Ext.Component', { region : 'north', height : 50, // give north and south regions a // height autoEl : { tag : 'div', html : '<p><h3>金智万维软件系统</h3></p>', bodyStyle : 'background:#ffc; padding:10px;' } }), { // lazily created panel (xtype:'panel' is default) region : 'south', contentEl : 'south', split : true, height : 100, minSize : 100, maxSize : 200, collapsible : true, collapsed : true, title : 'South', margins : '0 0 0 0' }, { xtype : 'tabpanel', region : 'east', title : 'East Side', dockedItems : [{ dock : 'top', xtype : 'toolbar', items : ['->', { xtype : 'button', text : 'test', tooltip : 'Test Button' }] }], animCollapse : true, collapsible : true, split : true, width : 225, // give east and west regions a width minSize : 175, maxSize : 400, margins : '0 5 0 0', activeTab : 1, tabPosition : 'bottom', items : [{ html : '<p>A TabPanel component can be a region.</p>', title : 'A Tab', autoScroll : true }, Ext.create('Ext.grid.PropertyGrid', { title : 'Property Grid', closable : true, source : { "(name)" : "Properties Grid", "grouping" : false, "autoFitColumns" : true, "productionQuality" : false, "created" : Ext.Date.parse( '10/15/2006', 'm/d/Y'), "tested" : false, "version" : 0.01, "borderWidth" : 1 } })] }, { region : 'west', stateId : 'navigation-panel', id : 'west-panel', // see Ext.getCmp() below title : '导航-ERP管理', split : true, width : 200, minWidth : 175, maxWidth : 400, collapsible : true, animCollapse : true, margins : '0 0 0 5', layout : 'accordion' //items : [treePanelView] } , this.tabPanel /*{ //title:'this is myPanel', region: 'center', // a center region is ALWAYS required for border layout id:'center-tab', deferredRender: false, activeTab: 0, // first tab initially active resizeEl: 'center-iframe' // items:[myFirstPanal] }*/] , initComponent:function(){ //var treePanelView=Ext.create('myApp.view.tree.myTreePanelView',{}); debugger var tabPanel=Ext.create('myApp.view.tree.tabPanels'); this.callParent(); } //renderTo: Ext.getBody() //渲染到页面 }); // get a reference to the HTML element with id "hideit" and add a click // listener to it // alert("hello world!!") }); //Ext.create('myApp.view.tree.indexPage',{}) //})();
myTreePanelView和tabPanels 是俩个define的类文件 可以引入但是不能实例化
弄了俩天还是出不来 ,求大神帮忙啊
相关推荐
在 Ext4 中,`Ext.Loader` 提供了这样的功能,使得开发者可以灵活地控制哪些类或文件应该在何时被加载。 下面我们将详细探讨 `Ext.Loader` 的使用方法和相关知识点: 1. **配置 `Ext.Loader`** 在使用 `Ext....
- 在给定的代码片段中,我们看到通过`Ext.onReady`函数来初始化Ext JS应用程序,确保DOM完全加载后再执行JS代码。 - 使用`Ext.require`导入了多个模块,如`Ext.form.*`、`Ext.tree.*`等,这表明开发者准备使用...
5. **实例化对象的方式**:推荐使用`Ext.create`函数代替`new`关键字创建对象,如`var win = Ext.create("Ext.window.Window", {...})`。这种方式更利于依赖注入和动态加载。 6. **动态类加载**:引入了`Ext.Loader...
4. **自动加载**:如果设置了`requires`或`uses`属性,Loader会在类实例化前自动加载所有必要的类。例如,`Ext.define('MyClass', { requires: ['OtherClass'] })`会确保`OtherClass`在`MyClass`使用前被加载。 5. ...
- **类库初始化**: 对于存在的类库,先加载基础类库文件,再加载具体的类库文件,并将类库实例化后添加到类数组中。 #### 总结 在CI框架中集成第三方类库(如PEAR)是一个常见的需求。通过上述步骤,我们可以轻松...
类的创建、继承和实例化变得更加规范,有助于代码组织和维护。 - **命名规范**:为了保证代码的可读性和一致性,ExtJS4提倡使用驼峰命名法,避免下划线和数字。类应组织在命名空间(包)下,如`MyCompany.data....
通过`Ext.Loader.setConfig`配置加载器路径,然后用`Ext.require`指定需要加载的模块,可以确保在需要时按需加载,从而提升应用的启动速度和用户体验。在实际开发中,合理利用这一特性可以显著改善大型应用的性能...
通过`Ext.create`实例化`MyApp.MyWindow`并调用`show`方法显示窗口。 2. 使用mixins实现功能重用: 在JavaScript中,`mixins`允许我们将行为插入到类中。在这里,我们定义了一个`MyApp.mixins.log`,包含`start...
通过 `setPath` 和 `require` 等方法,可以在运行时按需加载文件。启用动态加载的配置如下: ```javascript Ext.Loader.setConfig({ enabled: true, paths: { 'My': 'my_own_path' } }); ``` - 这允许...
配置完成"classMap"后,运行应用程序实例,当程序中创建"JPhpMailer"类的实例时,由于"classMap"的存在,Yii框架的自动加载器会自动包含正确的文件路径,无需开发者再显式地使用Yii::import()来引入文件。...
这样设置了命名空间和加载路径后,你可以使用`Ext.ux.exporter.Exporter`这个组件来实现在Grid上的导出按钮。在你的Grid配置中添加一个`xtype: 'exporterbutton'`的组件,指定对应的store和Grid实例: ```...
这个方法首先调用 `createApplication` 静态方法,然后通过 `new CWebApplication($config)` 实例化 `CWebApplication`,这个类继承自 `CApplication`,因此也会执行 `CApplication` 的构造函数。 4. **构造函数及...
3. **使用示例**:在控制器中,实例化PHPExcel对象,创建或读取Excel文件。例如,要创建一个新的Excel文件并写入数据: ```php $objPHPExcel = new \PHPExcel(); $sheet = $objPHPExcel->getActiveSheet(); $...
接着,我们需要引入Echarts的JS文件,并在页面加载完成后初始化Echarts实例。这通常可以通过`require`或`import`语句完成。然后,我们可以通过Echarts的`echarts.init`方法来初始化图表容器,并设置相应的配置选项,...
这里的`main.js`文件通常是每个Vue应用的入口,导入Vue实例和组件等。 2. **配置多个输出(output)** 对应于每个入口,你需要配置相应的输出路径和文件名。这通常涉及`path`和`filename`属性: ```javascript ...
//实例化 使用此种方法是为了兼容PHP4 与PHP5 复制代码 这里我们进到./source/class/class_core.php 看看这个核心类 首先来分别看看这些属性 var $db = null;//存储数据库对象 var $mem = null;//存储内存缓存对象 ...
- 构造函数__construct($dir='', $lifetime=1800):在实例化缓存类时,可以通过构造函数设置缓存目录和缓存有效期,默认有效期为1800秒。此外,会检查缓存目录是否存在且有效,如果目录不存在,则会尝试创建该目录。...
`引入Java类,然后实例化并调用Java类的方法。例如: ```php require_once("java/Java.inc"); header("content-type:text/html; charset=utf-8"); // 获取Java类的实例 $system = new Java('java.lang....
在示例中,`require.config`用于配置模块加载路径,确保`echarts`以及`echarts/chart`下的`bar`, `line`, 和 `pie`模块能够正确加载。这样,我们就可以在页面上初始化ECharts实例并绘制所需图表。 ```javascript ...
`extract-text-webpack-plugin`是Webpack中的一个插件,主要用于从JavaScript模块中提取CSS代码,避免将其内联到JS文件中导致样式加载混乱的问题。在Web开发中,将CSS与JavaScript分离有利于提高页面加载效率,避免...