我有一个奇怪的问题,我不知道该如何解决。主要是因为我看不出我做错了什么。
我使用的是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 (这不应该有任何影响)。这里的情况更糟;我设置了一个断点,然后猜怎么着,当我对列进行排序时,它没有命中?!
到底怎么回事!?
提前谢谢。
发布于 2015-01-09 11:17:18
都是好人。我犯了一个小小的错误,结果发现我没有把它连到TreeList上,这是我自己的愚蠢行为所挫败的。
发布于 2015-01-09 10:23:20
您需要处理事件CompareNodeValues (DevExpress站点上的示例)
private void mytree_CompareNodeValues(object sender,DevExpress.XtraTreeList.CompareNodeValuesEventArgs e) {
if (e.Column == myspecialsortcolumn) {
e.Result = Convert.ToDecimal(e.NodeValue1) - Convert.ToDecimal(e.NodeValue2);
}
}https://stackoverflow.com/questions/27856987
复制相似问题