Heim > Web-Frontend > Front-End-Fragen und Antworten > Lassen Sie uns über das JQuery-Diagramm mit ungleichmäßigem Maßstab sprechen

Lassen Sie uns über das JQuery-Diagramm mit ungleichmäßigem Maßstab sprechen

PHPz
Freigeben: 2023-04-06 10:12:50
Original
571 Leute haben es durchsucht

jQuery ist eine weit verbreitete JavaScript-Bibliothek, die viele praktische und schnelle Methoden und Funktionen zum Erzielen dynamischer Webseiteneffekte und Interaktivität bietet. In Bezug auf die Datenvisualisierung verfügt jQuery auch über viele verwandte Plug-Ins und Tools, darunter das ungleichmäßige Diagramm.

Ein Diagramm mit ungleichmäßigem Maßstab bedeutet, dass auf der horizontalen Achse der Abstand zwischen Datenpunkten nicht festgelegt ist, sondern nach einem bestimmten Verhältnis oder einer bestimmten Regel verteilt ist. Diese Art von Diagramm wird normalerweise verwendet, um Zeitreihendaten oder Datenpunkte mit unterschiedlichen Attributen anzuzeigen, um die Beziehung zwischen Datenpunkten klarer darzustellen.

Bei der Implementierung von Diagrammen mit ungleichmäßigem Maßstab bietet jQuery einige praktische und benutzerfreundliche Plug-Ins. Die am häufigsten verwendeten sind D3.js und Highcharts. Im Folgenden wird die Verwendung dieser beiden Plug-Ins vorgestellt.

Zuerst ist D3.js. D3.js ist eine datengesteuerte JavaScript-Bibliothek, die durch die Bearbeitung von DOM-Dokumenten Datenvisualisierungseffekte erzielt. Wenn wir D3.js verwenden, um ungleichmäßig skalierte Diagramme zu implementieren, können wir dies erreichen, indem wir den Maßstab und die Achse definieren. Skalen werden verwendet, um Daten Pixelpositionen auf der horizontalen Achse zuzuordnen, während Achsen zum Zeichnen von Häkchen und Beschriftungen auf der horizontalen Achse verwendet werden.

Das Folgende ist ein einfaches Beispiel, das zeigt, wie man mit D3.js ein Liniendiagramm mit ungleichmäßigen Maßstäben implementiert:

<!DOCTYPE html>
<html>
<head>
  <meta charset="utf-8">
  <title>D3.js刻度不均匀图表</title>
  <script src="https://d3js.org/d3.v5.min.js"></script>
</head>
<body>
  <svg width="960" height="500"></svg>
  <script>
    // 数据
    var data = [
      {x: 1, y: 10},
      {x: 2, y: 20},
      {x: 4, y: 30},
      {x: 7, y: 40},
      {x: 10, y: 50},
      {x: 15, y: 60},
      {x: 23, y: 70},
      {x: 30, y: 80},
      {x: 40, y: 90},
      {x: 50, y: 100}
    ];
    
    // 定义比例尺和轴
    var xScale = d3.scaleLinear()
      .domain([1, 50])
      .range([0, 960]);
    
    var xAxis = d3.axisBottom(xScale)
      .ticks(10)
      .tickValues([1, 2, 4, 7, 10, 15, 23, 30, 40, 50]);
    
    // 绘制折线图
    var svg = d3.select("svg");
    
    svg.append("path")
      .datum(data)
      .attr("fill", "none")
      .attr("stroke", "steelblue")
      .attr("stroke-width", 2)
      .attr("d", d3.line()
        .x(function(d) { return xScale(d.x); })
        .y(function(d) { return d.y; })
      );
    
    // 绘制坐标轴
    svg.append("g")
      .attr("transform", "translate(0, 400)")
      .call(xAxis);
  </script>
</body>
</html>
Nach dem Login kopieren

In diesem Beispiel definieren wir einen Datensatz mit 10 Datenpunkten. Durch die Definition von Maßstab und Achse verteilen wir den Abstand zwischen Datenpunkten ungleichmäßig über die horizontale Achse. Beim Zeichnen des Liniendiagramms haben wir die von D3.js bereitgestellte Funktion .line() verwendet, um den Datensatz dem SVG-Pfad zuzuordnen. Abschließend wird die horizontale Achse gezeichnet und die Maßstäbe und Beschriftungen festgelegt.

Die nächste Einführung ist Highcharts. Highcharts ist eine voll funktionsfähige JavaScript-Diagrammbibliothek, die mehrere Arten von Diagrammen, Interaktivität und dynamische Effekte bietet.

Es ist auch sehr einfach, Diagramme mit ungleichmäßigem Maßstab in Highcharts zu implementieren. Wir können die jedem Datenpunkt entsprechende horizontale Achsenkoordinate definieren, indem wir das Kategorienattribut der x-Achse festlegen, wie unten gezeigt:

<!DOCTYPE html>
<html>
<head>
  <meta charset="utf-8">
  <title>Highcharts刻度不均匀图表</title>
  <script src="https://code.highcharts.com/highcharts.js"></script>
</head>
<body>
  <div id="container"></div>
  <script>
    // 数据
    var data = [
      {name: '1', y: 10},
      {name: '2', y: 20},
      {name: '4', y: 30},
      {name: '7', y: 40},
      {name: '10', y: 50},
      {name: '15', y: 60},
      {name: '23', y: 70},
      {name: '30', y: 80},
      {name: '40', y: 90},
      {name: '50', y: 100}
    ];
    
    // 绘制图表
    Highcharts.chart('container', {
      chart: {
        type: 'line'
      },
      title: {
        text: 'Highcharts刻度不均匀图表'
      },
      xAxis: {
        categories: ['1', '2', '4', '7', '10', '15', '23', '30', '40', '50']
      },
      yAxis: {
        title: {
          text: 'Y轴标题'
        }
      },
      series: [{
        name: '数据点',
        data: data
      }]
    });
  </script>
  </body>
</html>
Nach dem Login kopieren

In diesem Beispiel verwenden wir auch einen Datensatz mit 10 Datenpunkten. Beim Zeichnen des Diagramms haben wir das Kategorienattribut der x-Achse angegeben und die jedem Datenpunkt entsprechende horizontale Achsenkoordinate festgelegt, wodurch der Effekt einer ungleichmäßigen Skalierung erzielt wurde.

Zusätzlich zu den beiden oben genannten Plug-Ins gibt es viele weitere jQuery-Bibliotheken und Plug-Ins, mit denen sich Diagramme mit ungleichmäßigem Maßstab implementieren lassen. Unabhängig davon, welchen Ansatz Sie wählen, muss die Auswahl auf Ihrem spezifischen Datentyp und Ihren Anforderungen basieren. Im Vergleich zu gewöhnlichen Diagrammen können Diagramme mit ungleichem Maßstab die Beziehung zwischen Datenpunkten intuitiver darstellen und Benutzern dabei helfen, Daten besser zu verstehen und zu analysieren.

Das obige ist der detaillierte Inhalt vonLassen Sie uns über das JQuery-Diagramm mit ungleichmäßigem Maßstab sprechen. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage