ExtJS 网格列:展开列以显示完整内容

发布于 2025-01-02 02:26:43 字数 194 浏览 0 评论 0原文

我创建了一个具有固定宽度的列的网格。 由于宽度固定,某些列无法扩展至足以显示完整内容,至少对于某些单元格而言是如此。

现在我正在寻找一种在双击标题时展开此列的方法。

我注意到 ColumnModel 中有一个函数 setColumnWidth() ,但要继续执行此操作,我必须获取内容的最大长度。

有人有什么建议吗?提前致谢!

I created a grid having columns with fixed width.
Due to the fixed width, some columns are not expanded enough to show full content, at least for some cells.

Now I am looking for a way to expand this column when double clicks at its header.

I noticed there is a function setColumnWidth() in ColumnModel, but to proceed this I have to get the maximum length of the content.

anybody has some advice? thanks in advance!

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

云雾 2025-01-09 02:26:43

不确定是否将专栏扩展到内容的长度,这可能是一件好事。异常多的内容最终可能会使网格看起来很糟糕。但是,您可以将 Flex 添加到要扩展的任何列。

columns: [{
    header: 'Blah',
    width: 100,
    dataIndex: 'Blah'
},{
    header: 'Foo',
    flex: 1,
    dataIndex: 'Foo'
}]

在该位中,Foo 列将扩展以占用 Blah 被分配为 100px 后留下的剩余空间。

Not sure about expanding the column to the length of the content, and that may be a good thing. An unusually long amount of content may end up making the grid look awful. However, you could add a flex to any column you want to expand.

columns: [{
    header: 'Blah',
    width: 100,
    dataIndex: 'Blah'
},{
    header: 'Foo',
    flex: 1,
    dataIndex: 'Foo'
}]

In that bit, the Foo column will expand to take the remaining space left behind after Blah was allotted it's 100px.

空城缀染半城烟沙 2025-01-09 02:26:43

知道这是一个旧线程,但我想分享它,因为我遇到了同样的问题。

我通过重写 Ext.grid.column.Column 的单击事件处理程序解决了这个问题。有一个私有的 onElDblClick 事件,用于双击列标题的边缘。
重写此函数还可以处理整个列标题上的双击。
接下来是重写 onElClick 事件处理程序,让它知道可能有一个通过 SetTimeout 调用挂起的双击操作,否则将始终调用附加到单击事件的任何事件(例如排序和下拉菜单)。

请参阅下面的代码来覆盖它。我只在 ExtJS 4.1.1a 上测试过它,但可以轻松移植到其他 ExtJS 版本。

    // enable doubleclick on the column to expand it to the max width as well
    Ext.override(Ext.grid.column.Column, {
        /**
         * @private
         * Double click
         * @param e
         * @param t
         */
        onElDblClick: function(e, t) {
            var me = this,
                ownerCt = me.ownerCt;
            if (ownerCt && Ext.Array.indexOf(ownerCt.items, me) !== 0) {
                if (me.isOnLeftEdge(e) ) {
                    ownerCt.expandToFit(me.previousSibling('gridcolumn'));
                } else {
                    ownerCt.expandToFit(me);
                }
            }
        },
        onElClick: function(e, t) {
            // The grid's docked HeaderContainer.
            var me = this,
                ownerHeaderCt = me.getOwnerHeaderCt();

            if (me.el.getAttribute("data-dblclick") == null) {
                me.el.dom.setAttribute("data-dblclick", 1);
                setTimeout(function () {
                    if (me.el.getAttribute("data-dblclick") == 1) {
                        handleElClick(me, e, t);
                    }
                    me.el.dom.removeAttribute("data-dblclick");
                }, 300);
            } else {
                me.el.dom.removeAttribute("data-dblclick");
                me.onElDblClick(e, t);
            }

            function handleElClick(me, e, t) {
                var ownerHeaderCt = me.getOwnerHeaderCt();
                if (ownerHeaderCt && !ownerHeaderCt.ddLock) {
                    // Firefox doesn't check the current target in a within check.
                    // Therefore we check the target directly and then within (ancestors)
                    if (me.triggerEl && (e.target === me.triggerEl.dom || t === me.triggerEl.dom || e.within(me.triggerEl))) {
                        ownerHeaderCt.onHeaderTriggerClick(me, e, t);
                    // if its not on the left hand edge, sort
                    } else if (e.getKey() || (!me.isOnLeftEdge(e) && !me.isOnRightEdge(e))) {
                        me.toggleSortState();
                        ownerHeaderCt.onHeaderClick(me, e, t);
                    }
                }
            }
        }
    });

双击检查是我在https://stackoverflow.com/a/16033129/3436982找到的改编版本。

Knowing this is an old thread, but I would like to share it as I had the same issue.

I solved it through overriding the click event handlers of Ext.grid.column.Column. There is a private onElDblClick event handled for double clicking on the edge of the column header.
Override this function to also handle double click on the entire column header.
Next is to override the onElClick event handler to let it know there could be a double click action pending via a SetTimeout call, otherwise any events attached to the single click event like sorting and the pull down menu will be called always.

See the below code to override it. I only tested it on ExtJS 4.1.1a, but would be easily ported to other ExtJS versions.

    // enable doubleclick on the column to expand it to the max width as well
    Ext.override(Ext.grid.column.Column, {
        /**
         * @private
         * Double click
         * @param e
         * @param t
         */
        onElDblClick: function(e, t) {
            var me = this,
                ownerCt = me.ownerCt;
            if (ownerCt && Ext.Array.indexOf(ownerCt.items, me) !== 0) {
                if (me.isOnLeftEdge(e) ) {
                    ownerCt.expandToFit(me.previousSibling('gridcolumn'));
                } else {
                    ownerCt.expandToFit(me);
                }
            }
        },
        onElClick: function(e, t) {
            // The grid's docked HeaderContainer.
            var me = this,
                ownerHeaderCt = me.getOwnerHeaderCt();

            if (me.el.getAttribute("data-dblclick") == null) {
                me.el.dom.setAttribute("data-dblclick", 1);
                setTimeout(function () {
                    if (me.el.getAttribute("data-dblclick") == 1) {
                        handleElClick(me, e, t);
                    }
                    me.el.dom.removeAttribute("data-dblclick");
                }, 300);
            } else {
                me.el.dom.removeAttribute("data-dblclick");
                me.onElDblClick(e, t);
            }

            function handleElClick(me, e, t) {
                var ownerHeaderCt = me.getOwnerHeaderCt();
                if (ownerHeaderCt && !ownerHeaderCt.ddLock) {
                    // Firefox doesn't check the current target in a within check.
                    // Therefore we check the target directly and then within (ancestors)
                    if (me.triggerEl && (e.target === me.triggerEl.dom || t === me.triggerEl.dom || e.within(me.triggerEl))) {
                        ownerHeaderCt.onHeaderTriggerClick(me, e, t);
                    // if its not on the left hand edge, sort
                    } else if (e.getKey() || (!me.isOnLeftEdge(e) && !me.isOnRightEdge(e))) {
                        me.toggleSortState();
                        ownerHeaderCt.onHeaderClick(me, e, t);
                    }
                }
            }
        }
    });

The double click check is an adapted version I found here https://stackoverflow.com/a/16033129/3436982.

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文