suchen

Heim  >  Fragen und Antworten  >  Hauptteil

Erstellen Sie eine <select>-Methode zum Auswählen von Zeichnungsdiagrammdateien

<p>Ich habe ein Diagramm, das mit Daten aus einer externen Datei erstellt wurde. Jetzt möchte ich ein Auswahlfeld, in dem der Benutzer die zu lesende Datei auswählen kann. Auf diese Weise kann sich das Diagramm dynamisch ändern. Wie kann ich Vue und ChartJS verwenden, um diese Funktionalität zu erreichen? </p> <p>Derzeit importiere ich Daten in Home wie folgt:</p> <pre class="brush:php;toolbar:false;"><template> <div class="home"> <Graph :vul_data="data"/> </div> </template> <script> import { Component, Prop, Vue } from 'vue-property-decorator'; Diagramm aus '@/components/Graph.vue' importieren; {Daten} aus '@/data/dataFile.js' importieren @Komponente({ Komponenten: { Graph, }, }) Standardklasse exportieren HomeView erweitert Vue { Daten() { zurückkehren { Daten: Daten, } } } </script></pre> <p>Die Daten für jede Datei lauten wie folgt: </p> <pre class="brush:php;toolbar:false;">const data exportieren = { „Punkte“: { "Linie 1": { "X": [ -11, -11, ], „y“: [ 7, 8, ] }, }, }</pre> <p>Die Komponenten sind wie folgt:</p> <pre class="brush:php;toolbar:false;"><template> <div> <canvas id="myChart"></canvas> </div> </template> <script> Diagramm aus „chart.js/auto“ importieren; Standard exportieren{ Name: „Grafik“, Requisiten: ["vul_data"], mount(){ const ctx = document.getElementById('myChart'); const myChart = new Chart(ctx, { Typ: 'Scatter', Daten: { Datensätze: [{ Beschriftung: 'Zeile 1', Daten:[ {x: this.vul_data.points.line1.x[0], y: this.vul_data.points.line1.y[0]}, {x: this.vul_data.points.line1.x[1], y: this.vul_data.points.line1.y[1]}, ], }, ] }, }); } } </script> <Stil> </style></pre>
P粉022140576P粉022140576500 Tage vor581

Antworte allen(1)Ich werde antworten

  • P粉107991030

    P粉1079910302023-08-21 09:01:01

    您可以使用<select>标签,其中的选项包含与您的.js文件名称相等的值。当选择发生变化时,运行一个方法,动态导入该文件并将导入的数据赋值给您作为属性传递给Graph组件的变量。简单的示例代码:

    <select @change="selectFile">
      <option value="dataFile1">文件一</option>
      <option value="dataFile2">文件二</option>
    </select>
    <Graph :vul_data="data" />
    
    data() {
      return {
        data: null,
      };
    },
    methods: {
      selectFile(e) {
        import(`@/data/${e.target.value}.js`).then((res) => {
          this.data = res.data;
        });
      },
    },
    

    Antwort
    0
  • StornierenAntwort