chartJs: я хочу показать обе легенды набора данных, когда наведу курсор на одну из точек? - PullRequest
0 голосов
/ 12 октября 2018

current behaviour

Я новичок в его использовании.Кроме того, я начал месяц с меток жесткого кода, начиная с января по декабрь.Как я могу ранжировать этикетки с января по настоящее время.Другая проблема, как вы можете видеть на картинке, когда я наведусь на точку.Отображается только эта точечная панель инструментов. Я хочу видеть все всплывающие подсказки точек, которые находятся на одной линии

Код

var ctx = document.getElementById("myChart");
  ctx.height = 50;
  var myChart = new Chart(ctx, {
      type: 'line',
      data: {
          labels: monthNames,
          datasets: [{
              label: "Sales",
              data: [2000, 1200, 3000, 5000, 1000, 1300],
              pointHoverBackgroundColor:  'rgb(255, 99, 132)',  
              backgroundColor: [
                  'rgba(255, 99, 132, 0.2)',
                  'rgba(54, 162, 235, 0.2)',
                  'rgba(255, 206, 86, 0.2)',
                  'rgba(75, 192, 192, 0.2)',
                  'rgba(153, 102, 255, 0.2)',
                  'rgba(255, 159, 64, 0.2)'
              ],
              borderColor: [
                  'rgba(255,99,132,1)',
                  'rgba(54, 162, 235, 1)',
                  'rgba(255, 206, 86, 1)',
                  'rgba(75, 192, 192, 1)',
                  'rgba(153, 102, 255, 1)',
                  'rgba(255, 159, 64, 1)'
              ],
              borderWidth: 1
          },
          {
              label: "gross sales",
              data: [1500, 2200, 3000, 2800, 1122, 2345],
              pointHoverBackgroundColor:  'rgb(66, 133, 244)',   
              backgroundColor: [
                  'rgb(66, 133, 244, 0.2)',                 
              ],
              borderColor: [
                  'rgb(66, 133, 244)',                  
              ],
              borderWidth: 1
          }]
      },
      options: {
        title:{
          display: "true",
          text: "Sales Reports",
          fontSize: "22"
        },
        tooltips:{
          intersect: false
        },
        scales: {
            yAxes: [{
                ticks: {
                    beginAtZero:true
                }
            }]
        }
      }

});

1 Ответ

0 голосов
/ 12 октября 2018

Вы можете установить свойство hover intersect для достижения этой цели.Вот вам скрипка -> http://jsfiddle.net/6n3w0qkh/5/.

Надеюсь, это поможет!

var ctx = document.getElementById("myChart");  
  var myChart = new Chart(ctx, {
      type: 'line',
      data: {
          labels: ['A', 'B', 'C', 'D', 'E', 'F'],
          datasets: [{
              label: "Sales",
              data: [2000, 1200, 3000, 5000, 1000, 1300],
              pointHoverBackgroundColor:  'rgb(255, 99, 132)',  
              backgroundColor: [
                  'rgba(255, 99, 132, 0.2)',
                  'rgba(54, 162, 235, 0.2)',
                  'rgba(255, 206, 86, 0.2)',
                  'rgba(75, 192, 192, 0.2)',
                  'rgba(153, 102, 255, 0.2)',
                  'rgba(255, 159, 64, 0.2)'
              ],
              borderColor: [
                  'rgba(255,99,132,1)',
                  'rgba(54, 162, 235, 1)',
                  'rgba(255, 206, 86, 1)',
                  'rgba(75, 192, 192, 1)',
                  'rgba(153, 102, 255, 1)',
                  'rgba(255, 159, 64, 1)'
              ],
              borderWidth: 1
          },
          {
              label: "gross sales",
              data: [1500, 2200, 3000, 2800, 1122, 2345],
              pointHoverBackgroundColor:  'rgb(66, 133, 244)',   
              backgroundColor: [
                  'rgb(66, 133, 244, 0.2)',                 
              ],
              borderColor: [
                  'rgb(66, 133, 244)',                  
              ],
              borderWidth: 1
          }]
      },
      options: {
        title:{
          display: "true",
          text: "Sales Reports",
          fontSize: "22"
        },
        tooltips: {
            mode: 'index',
            intersect: false
        },
        hover: {
            mode: 'nearest',
            intersect: true
        },
        scales: {
            yAxes: [{
                ticks: {
                    beginAtZero:true
                }
            }]
        }
      }
});
...