【问题标题】:DevExpress XtraTreeList Columns Sorting NumericalDevExpress XtraTreeList 列排序数字
【发布时间】:2015-01-09 09:04:24
【问题描述】:

我有一个奇怪的问题,我不确定如何解决。主要是因为我看不出我做错了什么。

我正在使用 DevExpress TreeList 控件。我有多个列,主要问题是在对列进行数字排序时,列按字母顺序排序,例如:

56.2, 57.3, 63.4, 78.9... then 8.3.

所以它按字母顺序排序。我已经多次将UnboundType 设置为Decimal,并将SortMode 更改为Value,并且我尝试过Default。我还尝试将UnboundType 更改为Object。我也尝试将FormatMode 更改为Numeric,但仍然会发生这种情况。我确实在 DX 上找到了一个帖子,但它没用,与我的情况无关。

有人可以帮忙吗?有没有人遇到过这个问题?如果您有任何想法,我将不胜感激。

提前致谢!


感谢马尔科的回复。我已经阅读了该 KB,我尝试使用以下事件处理程序设置 SortMode: Custom

private void trResults_CompareNodeValues(object sender, DevExpress.XtraTreeList.CompareNodeValuesEventArgs e)
        {
            if (e.Column == colSize)
            {
                try
                {
                    int value1 = Convert.ToInt32(Regex.Replace((e.NodeValue1 as string), "[^0-9.]", ""));
                    int value2 = Convert.ToInt32(Regex.Replace((e.NodeValue2 as string), "[^0-9.]", ""));
                    e.Result = value1 - value2;
                }
                catch { }
            }
        }

我已经按照您的方式进行了尝试,并且使用了我的 RegEx(应该没有任何效果)。这是变得更糟的地方;我设置了一个断点,你猜怎么着,当我对列进行排序时,它没有命中?!

这到底是怎么回事!?

提前致谢。

【问题讨论】:

    标签: devexpress xtratreelist columnsorting


    【解决方案1】:

    您需要处理事件 CompareNodeValues (Example on DevExpress site)

    private void mytree_CompareNodeValues(object sender,DevExpress.XtraTreeList.CompareNodeValuesEventArgs e) {
       if (e.Column == myspecialsortcolumn) {
         e.Result = Convert.ToDecimal(e.NodeValue1) - Convert.ToDecimal(e.NodeValue2);
       }
    }
    

    【讨论】:

      【解决方案2】:

      都是好人。我犯了一个小错误,结果我没有将偶数连接到 TreeList,被我自己的白痴所挫败。

      【讨论】: