gpt4 book ai didi

javascript - 按日期排序数组会产生意想不到的结果

转载 作者:IT王子 更新时间:2023-10-29 03:22:28 26 4
gpt4 key购买 nike

这听起来是个简单的问题,但我花了我的星期天时间试图弄清楚下面描述的我的实现有什么问题,所以我将它发布到 SO 作为最后的手段。

我有一个从服务器接收数据结构的 javascript 应用程序。服务器端出于性能原因发送未排序的数据。

这是接收数据的 javascript 代码片段:

    var seriesRawDataArray = ko.observableArray();
...
analyticscontext.series(seriesRawDataArray).done(function () {
renderSeries();
});

analyticscontext模块使用ajax查询数据:

function series(seriesData) {
return $.ajax({
url: "/api/analytics/series",
type: "GET",
success: function (data) {
return seriesData(data);
}
});
}

renderSeries 在渲染之前对数据进行排序:

    // Sort the data by date using moment.js
seriesRawDataArray.sort(function (left, right) {
var leftDate = moment.utc(left.timeStamp);
var rightDate = moment.utc(right.timeStamp);
var diff = leftDate.diff(rightDate);
return diff > 0;
});

问题

这是我从服务器收到的数据示例: enter image description here

注意末尾未分类的项目。seriesRawDataArray.sort 似乎对原始数组没有影响,无论我在排序方法中更改什么,原始数组都不会排序。输出总是:

enter image description here

注意这里的未排序元素。我正在使用的库和数据绝对不是这个 jsfiddle 的问题工作得很好!这段代码有问题吗?

最佳答案

简答

您应该返回两个日期之间的差异,而不是 bool 值:

// sort the data by date using moment.js
seriesRawDataArray.sort(function (left, right) {
return moment.utc(left.timeStamp).diff(moment.utc(right.timeStamp))
});

为什么

Array.prototype.sort期望返回负值、零值或正值。通常,您将编写这样的排序函数:

yourArray.sort(function (a, b) {
if (a < b) { // a comes first
return -1
} else if (b < a) { // b comes first
return 1
} else { // equal, so order is irrelevant
return 0 // note: sort is not necessarily stable in JS
}
})

传递给排序的匿名函数用作排序函数的 native 实现的比较器。

但是,您的负值不必是-1,您的正值也不必是+1。因此,在对数字进行排序时,您可以改用快捷方式:

yourArray.sort(function (a, b) {
return a - b
})

在 JavaScript 中,减去两个日期会将它们都转换为数字,这就是为什么我们可以使用 return moment.utc(left.timeStamp).diff(moment.utc(right.timeStamp))

(不是直接减法-,此方法使用moment.js 库中的moment.prototype.diff)

但是,在您的代码中,您返回了diff > 0,它可以是truefalse .由于类型强制,JavScript 会将 true 读取为 1,将 false 读取为 0。这意味着您的排序函数永远不会返回 -1。因此,您的元素将不会正确排序。

关于javascript - 按日期排序数组会产生意想不到的结果,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28013045/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com