论坛首页 Web前端技术论坛

ExtJS 2.3/3.0 定制你所需要的模块

浏览 10145 次
精华帖 (1) :: 良好帖 (0) :: 新手帖 (0) :: 隐藏帖 (0)
作者 正文
   发表时间:2009-08-12   最后修改:2010-07-26

很实在的一个需求,就是我们只需要extjs的一部分功能,不想把整个类库都包含进来.

 

所以让我们来定制extjs吧~

 

 

1. ExtJS 1.1.1或2.3.0

 

可以用官方的在线工具来定制:http://extjs.com/products/extjs/build/

 

使用教程:

e文:http://extjs.com/learn/Tutorial:Building_Ext_From_Source

中文:http://extjs.org.cn/node/364

 

2. EXTJS 3.0

 

现在还没有在线版,可以通过以下方法来自己定制:

 

1. 下载Ext 3.0.0 SDK. http://extjs.com/products/extjs/download.php?dl=extjs3
2. 下载JSBuilder2. http://extjs.com/products/jsbuilder/   (或者看文末的附件)
3. 下载Ext 3.0.0的ext.jsb2文件   http://extjs.com/forum/showthread.php?p=354473  (或者看文末的附件)

注:现在的ext源码里面已经自带了jsb2文件了

4.  把JSBuilder2解压jar到extjs根目录下,ext.jsb2也放到根目录下

5.  用你的文本编辑器编辑ext.jsb2文件,仅保留你需要的模块

6.  jsb2文件中的deployDir: 'ext-3.0.0-build'表示相对输出目录

7.  cmd,切换到ext根目录下,执行:

 

G:\Learning\Web\Javascript\ExtJS\ext-3.0.0> java -jar "JSBuilder2.jar" -p ./ext.jsb2 -d ./ 

 

8.等待刷屏完毕后去你在jsb2中指定的目录下找输出吧.

 

 

3.试验

一个试验的例子,仅包含Tree组件,如附件

 

1) resource部分未作过滤

2) 注意依赖关系,如

        name: 'Trees',
        file: 'pkgs/pkg-tree.js',
        isDebug: true,
        pkgs: ['pkgs/cmp-foundation.js']

 

3)输出的文件树如下:

 

adapter\
|--ext\
|----ext-base.js
|----ext-base-debug.js

pkgs\
|--cmp-foundation.js
|--ext-foundation.js
|--pkg-tree.js
|--cmp-foundation-debug.js
|--ext-foundation-debug.js
|--pkg-tree-debug.js

resources\
license.txt

 

 

2009-08-25更新:

extjs3.0的一种简化的提取方式,就是官方本身已经压缩过一次了,看pkgs目录下有很多文件.

然后再看jsb2中提到的依赖,来提取就OK了,如tabpanel是:

{
  name: 'TabPanel',
   file: 'pkgs/pkg-tabs.js',
   isDebug: true,
   pkgs: ['pkgs/cmp-foundation.js'],
   fileIncludes: [{
     text: 'TabPanel.js',
     path: 'src/widgets/'       
  }]   
}
如果你只用tab,不用其他的,那试着只引入pkgs下的
cmp-foundation.js和pkg-tabs.js

 

2009-07-26更新:

[quote="y1d2y3xyz"]我不知到你是怎么做的,按照你tree的步骤根本不能实现,还希望楼主能给我DEMO演示,我目前正需要EXT的这棵树,可惜按你的意思高了好多次都失败,报错,悲剧啊,[/quote]


在extjs3.2中,tree需要:
  <script type="text/javascript" src="../js/extjs/3.2.0/adapter/ext/ext-base.js"></script>
  <script type="text/javascript" src="../js/extjs/3.2.0/pkgs/ext-foundation.js"></script>
  <script type="text/javascript" src="../js/extjs/3.2.0/pkgs/cmp-foundation.js"></script>
  <script type="text/javascript" src="../js/extjs/3.2.0/pkgs/ext-dd.js"></script>
  <script type="text/javascript" src="../js/extjs/3.2.0/pkgs/pkg-tree.js"></script>

在3.0后,官方的源码中就带有这些pkgs了,不需要jsbuilder来自己生成.

其中,enableDD,containerScroll那几个属性需要的是ext-dd.js,这个在jsb2中确实是没有提到.
但是看报错,一般可以猜出是哪个包,然后引入对应的文件.

Ext.onReady(function(){
  Ext.BLANK_IMAGE_URL = '../js/extjs/3.2.0/resources/images/default/s.gif';
  //Ext.chart.Chart.CHART_URL = '../js/extjs/3.2.0/resources/charts.swf';
  //Ext.QuickTips.init();
  testTree();
});

function testTree(){
  var tree = new Ext.tree.TreePanel({
    renderTo:Ext.getBody(),
    title: 'My Task List',
    height: 300,
    width: 400,
    useArrows:true,
    autoScroll:true,
    animate:true,
    enableDD:true,
    containerScroll: true,
    rootVisible: false,
    frame: true,
    root: {
      nodeType: 'async'
    },
    dataUrl: 'check-nodes.json'
  });
  tree.getRootNode().expand(true);
}
 

 

   发表时间:2009-08-15  
太帅了,还不知道可以这样手工操作
0 请登录后投票
   发表时间:2009-08-21  
这个好。。。一直想找个3.0定制的方法
0 请登录后投票
   发表时间:2009-08-25  
extjs3.0的一种简化的提取方式,就是官方本身已经压缩过一次了,看pkgs目录下有很多文件.

然后再看jsb2中提到的依赖,来提取就OK了,如tabpanel是:

{
  name: 'TabPanel',
   file: 'pkgs/pkg-tabs.js',
   isDebug: true,
   pkgs: ['pkgs/cmp-foundation.js'],
   fileIncludes: [{
     text: 'TabPanel.js',
     path: 'src/widgets/'      
  }]  
}
如果你只用tab,不用其他的,那试着只引入pkgs下的
cmp-foundation.js和pkg-tabs.js
0 请登录后投票
   发表时间:2009-11-20  
朋友,我只想用Message,可是按照您的方法没有用呀?
我导入了cmp-foundation.js和window.js不行哦
0 请登录后投票
   发表时间:2010-07-22  
我不知到你是怎么做的,按照你tree的步骤根本不能实现,还希望楼主能给我DEMO演示,我目前正需要EXT的这棵树,可惜按你的意思高了好多次都失败,报错,悲剧啊,
0 请登录后投票
   发表时间:2010-07-26  
y1d2y3xyz 写道
我不知到你是怎么做的,按照你tree的步骤根本不能实现,还希望楼主能给我DEMO演示,我目前正需要EXT的这棵树,可惜按你的意思高了好多次都失败,报错,悲剧啊,



在extjs3.2中,tree需要:
  <script type="text/javascript" src="../js/extjs/3.2.0/adapter/ext/ext-base.js"></script>
  <script type="text/javascript" src="../js/extjs/3.2.0/pkgs/ext-foundation.js"></script>
  <script type="text/javascript" src="../js/extjs/3.2.0/pkgs/cmp-foundation.js"></script>
  <script type="text/javascript" src="../js/extjs/3.2.0/pkgs/ext-dd.js"></script>
  <script type="text/javascript" src="../js/extjs/3.2.0/pkgs/pkg-tree.js"></script>

在3.0后,官方的源码中就带有这些pkgs了,不需要jsbuilder来自己生成.

其中,enableDD,containerScroll那几个属性需要的是ext-dd.js,这个在jsb2中确实是没有提到.
但是看报错,一般可以猜出是哪个包,然后引入对应的文件.

Ext.onReady(function(){
  Ext.BLANK_IMAGE_URL = '../js/extjs/3.2.0/resources/images/default/s.gif';
  //Ext.chart.Chart.CHART_URL = '../js/extjs/3.2.0/resources/charts.swf';
  //Ext.QuickTips.init();
  testTree();
});

function testTree(){
  var tree = new Ext.tree.TreePanel({
    renderTo:Ext.getBody(),
    title: 'My Task List',
    height: 300,
    width: 400,
    useArrows:true,
    autoScroll:true,
    animate:true,
    enableDD:true,
    containerScroll: true,
    rootVisible: false,
    frame: true,
    root: {
      nodeType: 'async'
    },
    dataUrl: 'check-nodes.json'
  });
  tree.getRootNode().expand(true);
}
0 请登录后投票
论坛首页 Web前端技术版

跳转论坛:
Global site tag (gtag.js) - Google Analytics