我正在使用 vis-js timeline 库来构建时间线。
我需要对每组中的元素进行排序。
组就像示例中的 here 。
我看到我可以使用“项目中的 order
选项”来做到这一点,比如 here
但我无法理解它是如何工作的。
我试过这种方式:
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 。关于javascript - VisJS 时间线 : sorting items in timeline,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/24555787/