zoukankan      html  css  js  c++  java
  • How to use filters in a GridPanel

    You can just link statically required files in your index.html

    <link rel="stylesheet" type="text/css" href="scripts/ext/examples/ux/grid/css/GridFilters.css" />
    <link rel="stylesheet" type="text/css" href="scripts/ext/examples/ux/grid/css/RangeMenu.css" />
    <script type="text/javascript" src="scripts/ext/examples/ux/grid/FiltersFeature.js"></script>
    <script type="text/javascript" src="scripts/ext/examples/ux/grid/filter/Filter.js"></script>
    <script type="text/javascript" src="scripts/ext/examples/ux/grid/filter/StringFilter.js"></script>
    <script type="text/javascript" src="scripts/ext/examples/ux/grid/filter/ListFilter.js"></script>
    <script type="text/javascript" src="scripts/ext/examples/ux/grid/filter/BooleanFilter.js"></script>
    <script type="text/javascript" src="scripts/ext/examples/ux/grid/filter/NumericFilter.js"></script>
    <script type="text/javascript" src="scripts/ext/examples/ux/grid/filter/DateFilter.js"></script>
    <script type="text/javascript" src="scripts/ext/examples/ux/grid/menu/RangeMenu.js"></script>
     

    The reason that ExtJS tries to load ".../features/filter.js" is that the object that it is looking for ("features.filter") is not yet defined. ExtJS guesses this must be in a file called "features/filter.js". However, it is actually defined in "grid/FeaturesFilter.js" (where "features.filter" is defined as an "alias" to "Ext.ux.grid.FiltersFeature").

    Most people who have this problem have read the documentation and are trying to load Ext.ux.grid.FiltersFeature (usually at "ux/grid/FiltersFeature.js") but the timing of the load is such that it is not loaded when it is needed. Therefore, ExtJS tries to load the non-existent file.

    The key to solving this problem is to ensure that the "Ext.ux.grid.FiltersFeature" is fully loaded (not just the load initiated) by the time the grid is initializing with the filters feature.

    The sensible (and appropriate) thing is to put the "Ext.ux.grid.FiltersFeature" in the "requires"of the class extending the grid. This should ensure that the grid/FiltersFeature.js file is loaded before you need it.

    // This should work
    Ext.define("FrontSuite.view.MyGrid", {
        extend:  'Ext.grid.Panel',
        xtype:   'mygrid',
        requires: [
            'Ext.ux.grid.FiltersFeature'
        ],
        title:   'My Grid',
        ...
        features: [{
            ftype  : 'filters',
            encode : true
        }],
        columns: [
            { dataIndex: 'id', text: 'ID'},
            { dataIndex: 'name', text: 'Name'}
        ]
    }

    If for some reason, the file does not load in time, you can put a (seemingly redundant) requires "Ext.ux.grid.FiltersFeature" in the Ext.application() call (ExtJS 4+).

    Ext.application({
        name: 'MyNamespace',
        extend: 'MyNamespace.Application',
        controllers: ['MyController'],
        autoCreateViewport: true,
        paths: {
            'Ext.ux': 'path/to/my/ext/ux'
        },
        requires: [
            'Ext.ux.grid.FiltersFeature'
        ]
    });

    IMPORTANT NOTES ON CLASS LOAD TIMING: Putting the required class in the proper "requires" config for the proper requiring class is important so that when you do a build and create a minified Javascript file, you get only the bits of the ExtJS library code that are truly needed. However, you should watch the Javascript console for messages that say that ExtJS had to load a file synchronously. If it does this, the "correct" location for a "requires" should be supplemented by a "redundant requires" somewhere earlier, such as in Ext.application() as shown above.

    source:http://stackoverflow.com/questions/7359512/how-to-use-filters-in-a-gridpanel

  • 相关阅读:
    快速幂 --- CSU 1556: Jerry's trouble
    iOS masonry 不规则tagView布局 并自适应高度
    iOS 渐变色实现,渐变色圆环,圆环进度条
    iOS scrollView中嵌套多个tableView处理方案
    iOS 多网络请求同步并发
    iOS UIView添加阴影
    什么是比特币,什么是区块链,什么是挖矿,为什么要挖?关于比特币,关于区块链,你想要知道的
    Xcode wifi连接真机调试
    iOS 添加WKWebView导致控制器无法释放的问题
    解决百度网盘非会员下载速度限制的完整方案
  • 原文地址:https://www.cnblogs.com/sdream/p/5207349.html
Copyright © 2011-2022 走看看