VisJS Timeline:对时间线中的项目进行排序

2023-12-19

我在用着vis-js 时间轴 http://visjs.org/docs/timeline/用于构建时间线的库。 我需要对每个组中的元素进行排序。
组就像示例中一样here http://visjs.org/examples/timeline/groups/groupsOrdering.html。 我发现我可以使用“order项目中的选项”,例如here http://visjs.org/examples/timeline/items/itemOrdering.html
但我不明白它是如何工作的。

我尝试了这样的方法:

var groups = new vis.DataSet([
    {id: 0, content: 'First', value: 1},
    {id: 1, content: 'Third', value: 3},
    {id: 2, content: 'Second', value: 2}
]);

// create a dataset with items

var items = new vis.DataSet([
    {id: 0, group: 0, content: 'item 0', start: new Date(2014, 3, 17), end: new Date(2014, 3, 21)},
    {id: 1, group: 0, content: 'item 1', start: new Date(2014, 3, 19), end: new Date(2014, 3, 20)},
    {id: 2, group: 1, content: 'item 2', start: new Date(2014, 3, 16), end: new Date(2014, 3, 24)},
    {id: 3, group: 1, content: 'item 3', start: new Date(2014, 3, 23), end: new Date(2014, 3, 24)},
    {id: 4, group: 1, content: 'item 4', start: new Date(2014, 3, 22), end: new Date(2014, 3, 26)},
    {id: 5, group: 2, content: 'item 5', start: new Date(2014, 3, 24), end: new Date(2014, 3, 27)}
  ]);

  // create visualization
  var container = document.getElementById('visualization');
  var options = {

    editable: true
  };

var timeline = new vis.Timeline(container);
timeline.setOptions(options);
timeline.setGroups(groups);
var temp = items.get({
    order:function(a,b){
        return b.id-a.id;
        if(a.id > b.id)
            return -1;
        if(a.id < b.id)
            return 1;

        return 0;
    },
});

  timeline.setItems(temp);

多变的temp包含一个已排序的数组,但是当创建时间线时 - 在第三组项目中排序如下:item3, item2, item4.
但它们必须像这样排序item2, item3, item4.


您可以通过提供以下函数来对时间线中的项目进行排序order时间轴配置中的选项。您可以在启动时间线时定义它

var options = {
  order: function(a,b){
    return b.id-a.id;
  },
  editable: true
};

或初始化后

timeline.setOptions({
  order: function(a,b){
    return b.id-a.id;
  },
});

order 函数将使用两个参数调用,它们是要比较的项目对象。您可以在这里实现任何逻辑。您只需要返回一个整数值。如果返回值小于 0,则第二个项目(传递给的项目)b)将首先排序,如果返回值大于或等于 0,则第一项(传递给的项)a)将首先订购,第二个项目将其次订购。这是一个工作demo http://jsfiddle.net/rexzing/sf92g3mz/33/.

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

VisJS Timeline:对时间线中的项目进行排序 的相关文章

随机推荐