如何用datepicker过滤chart.js?

问题描述 投票:0回答:1

我是编程新手。我有一个由 chart.js 制作的图表,数据来自 API。这是我的API URL。https:/gmlews.comapidata?node_id=1

我想把API上的水分数据绘制在图表上,Y轴是水分数据,X轴是API上的时间戳。Y轴是水分数据,X轴是我在API上的时间戳。我试着使用datepicker来管理我想在图表上显示的数据。

所以,到目前为止,这是我的代码。

$(function() {

$('input[name="datefilter"]').daterangepicker({
    showDropdowns : true,
autoUpdateInput: false,
locale: {
    cancelLabel: 'Clear'
}
});

$('input[name="datefilter"]').on('apply.daterangepicker', function(ev, picker) {
$(this).val(picker.startDate.format('DD/MM/YYYY') + ' - ' + picker.endDate.format('DD/MM/YYYY'));
var fromDate = picker.startDate.format('DD/MM/YYYY');
var toDate = picker.endDate.format('DD/MM/YYY');
if (fromDate != '' && toDate != '') {
      console.log(fromDate, toDate);
      var endpoint = 'https://gmlews.com/api/data/?node_id=1';

 $.ajax({
 method: "GET",
 url: endpoint,
 data: {
 fromDate: fromDate,
 toDate: toDate
 },
 success: function(data){
 console.log(data); //get all data
 //get data by fields
 var hum = [], time = [];
 for (var i=0; i<data.length; i++){
  hum.push(data[i].moisture);
  time.push(data[i].timestamp);
 }
 console.log(hum);
 console.log(time);
//plot the chart

var ctx = document.getElementById("moistureChart").getContext('2d');
var moistureChart = new Chart(ctx, {
    type: 'line',
    data: {
        labels: time,
        datasets: [{
            label: 'kelembaban',
            data: hum,
            backgroundColor: [
                '#ff000000'
            ],
            borderColor: [
            '#331698'
            ],
            borderCapStyle: 'round',
            borderWidth: 1
        }]
    },
    options: {
        reponsive: true,
        scales: {
            yAxes: [{
                ticks: {
                    beginAtZero:false,
                    stepSize:10
                },
                  scaleLabel: {
                  display:     true,
                  labelString: 'kelembaban'
              }
            }],
            xAxes: [{

                    display: true,
                    type: "time",
                    time: {
                          minUnit: "hour",
                          unit: "hour",
                          unitStepSize: 6,
                          min: moment(fromDate).toDate(),//Date object type
                          max: moment(toDate).toDate()//Date object type
                    },
                  scaleLabel: {
                  display:     true,
                  labelString: 'Time'
              }
            }]
        }
    }
});
},
error: function(error_data){
console.log(error_data)
} 

});
} //if function
}); //tombol apply


$('input[name="datefilter"]').on('cancel.daterangepicker', function(ev, picker) {
$(this).val('');
});

});

你可以在这里访问fiddle的代码。https:/jsfiddle.netestri012ftu8g74c5。

问题是当我试图从datepicke中选择日期,例如:从5月7日到5月8日的日期,它不会加载任何东西,但实际上API中5月7日的数据是存在的。它不会加载任何东西,但实际上API中的数据5月7日是存在的。然后,当我试图选择5月13日至5月14日的日期,datepicker过滤器不工作,它只是显示所有的数据,我有在API。你能帮我解决这个问题吗?谢谢你!我是一个新的编程。

javascript json api datepicker chart.js
1个回答
1
投票

首先,你是想通过发送fromDate和toDate参数来过滤你的API数据,我达到了 https:/gmlews.comapidata?node_id=1。 但没有找到关于可以使用的参数的文档。

如果我尝试用&fromDate=2020-05-29&toDate=2020-05-29进行GET,我收到的数据和我调用没有参数的端点时的数据是一样的。

你不是应该发送一个时间戳而不是日期格式吗?

你的格式化日期是YYYY-MM-DD格式吗?

© www.soinside.com 2019 - 2024. All rights reserved.