Heim > Web-Frontend > js-Tutorial > So implementieren Sie eine benutzerdefinierte Visualisierung mit AngularJS2, das in D3.js integriert ist

So implementieren Sie eine benutzerdefinierte Visualisierung mit AngularJS2, das in D3.js integriert ist

亚连
Freigeben: 2018-06-22 18:32:26
Original
1607 Leute haben es durchsucht

In diesem Artikel wird hauptsächlich die Methode zur Integration von ANGULAR2 und D3.js vorgestellt, um eine benutzerdefinierte Visualisierung zu erreichen. Der Herausgeber findet sie recht gut, daher werde ich sie jetzt mit Ihnen teilen und als Referenz verwenden. Lassen Sie uns dem Editor folgen und einen Blick darauf werfen.

In diesem Artikel wird die Methode zur Integration von ANGULAR2 und D3.js vorgestellt, um eine benutzerdefinierte Visualisierung zu erreichen. Die Details sind wie folgt:

Ziel

  1. Trennung von Präsentationsschicht und Logikschicht

  2. Trennung von Daten- und Visualisierungskomponenten

  3. Zwei-Wege-Bindung von Daten und Ansicht, Aktualisierung in Echtzeit

  4. Die Codestruktur ist klar und einfach zu warten und zu ändern

Grundprinzipien

Angular2-Komponenten Lebenszyklus-Hook-Methode, Eltern-Kind-Komponenten-Interaktionsmechanismus, Vorlagensyntax

Quellcode-Analyse

Die Codestruktur ist sehr einfach, mit Ausnahme der Codestruktur der Homepage index.html und main.ts. Wie unten gezeigt:

Codestruktur

app.module.ts

import { BrowserModule } from '@angular/platform-browser';
import { NgModule } from '@angular/core';
import { FormsModule } from '@angular/forms';
//components
import { AppComponent } from './app.component';
import { Bubbles } from './bubbles.component';

@NgModule({
 declarations: [
  AppComponent,
  Bubbles
 ],
 imports: [
  BrowserModule,
  FormsModule
 ],
 providers: [],
 bootstrap: [AppComponent]
})
export class AppModule { }
Nach dem Login kopieren

app.component.html

Implementieren Sie die Definition der Hostansicht,

2 Schaltflächen, die Schaltflächen können an 2 Klickereignisse gebunden werden, ausführen entsprechende Aktionen, aktualisieren Sie das Array und schließen Sie die Aktualisierung des Blasendiagramms ab das Eingabedaten-Array des Blasendiagramms und das nachfolgende ist ein zufällig generiertes Array

<h1>
 <button (click)="refreshArr()" >开始刷新气泡图</button>
 <button (click)="stopRefresh()" >停止刷新气泡图</button>
 <bubbles [values]="numArray"></bubbles>
</h1>
Nach dem Login kopieren

app.component.ts

Aktualisieren Sie die Daten, indem Sie einen Timer angeben, der alle 3 Sekunden aktualisiert. Hinweis hier dass Sie zuerst das Array löschen und dann Elemente hinzufügen müssen, ohne die Referenz zu ändern, kann das Blasendiagramm nicht aktualisiert werden

import { Component, OnDestroy, OnInit } from &#39;@angular/core&#39;;
@Component({
 selector: &#39;app-root&#39;,
 templateUrl: &#39;./app.component.html&#39;,
 styleUrls: [&#39;./app.component.css&#39;]
})
export class AppComponent implements OnInit, OnDestroy {
 intervalId = 0;
 numArray = [];
 // 清除定时器
 private clearTimer() {
  console.log(&#39;stop refreshing&#39;);
  clearInterval(this.intervalId);
 }
 // 生成指定范围内的随机数
 private getRandom(begin, end) {
  return Math.floor(Math.random() * (end - begin));
 }
 ngOnInit() {
  for (let i in this.numArray) {
   this.numArray[i] = this.getRandom(0, 100000000); // "0", "1", "2",
  };
 }
 // 元素关闭清除定时器
 ngOnDestroy() { this.clearTimer(); }
 // 启动定时刷新数组
 refreshArr() {
  this.clearTimer()
  this.intervalId = window.setInterval(() => {
   this.numArray = [];
   for (let i=0;i<8;i++)
   {
    this.numArray.push(this.getRandom(0, 100000000));
   }
  }, 3000);
 }
 // 停止定时刷新数组
 stopRefresh() {
  this.clearTimer();
 }
}
Nach dem Login kopieren

bubbles.component.ts Blasendiagramm-Komponentenklasse

    ngOnChanges() Lebenszyklusmethode, die automatisch aufgerufen werden kann, wenn sich die Eingabeattributwerte ändern;
  1. @ViewChild kann einen Verweis auf erhalten das untergeordnete Element SVG, wobei die benutzerdefinierte Variable #target verwendet wird, um das untergeordnete SVG-Element
  2. import { Component, Input, OnChanges, AfterViewInit, ViewChild} from &#39;@angular/core&#39;;
    import {BubblesChart} from &#39;./bubbles.chart&#39;;
    declare var d3;
    @Component({
      selector: &#39;bubbles&#39;,
      template: &#39;<svg #target width="900" height="300"></svg>&#39;,
    })
    export class Bubbles implements OnChanges, AfterViewInit {
      @Input() values: number[];
      chart: BubblesChart;
      @ViewChild(&#39;target&#39;) target;//获得子组件的引用
      constructor() {
      }
      // 每当元素对象上绑定的数据 输入属性值 values 发生变化时,执行下列函数,实现图表动态变化
      ngOnChanges(changes) {
        if (this.chart) {
          // 先清空汽泡图,再重新调用汽泡图对象的render方法,根据变动后的值绘制图形
          this.chart.destroy();
          this.chart.render(changes.values.currentValue);
        }
      }
      
       ngAfterViewInit() {
          // 初始化汽泡图
          this.chart = new BubblesChart(this.target.nativeElement);
          this.chart.render(this.values);
        }
    }
    Nach dem Login kopieren
  3. bubbles.chart class

< zu identifizieren 🎜>D3.js syntaxdefinierte Blasendiagrammklasse, verfügt über eine Zeichenmethode und eine Löschmethode
  1. erforderlich. Zuerst
  2. declare var d3;
    // define a bubble chart class 
    // Exports the visualization module
    export class BubblesChart {
      target: HTMLElement;
      //构造函数, 基于一个 HTML元素对象内部来绘制
      constructor(target: HTMLElement) {
        this.target = target;
      }
      // 渲染 入参为数值 完成基于一个数组的 汽泡图的绘制
      render(values: number[]) {
        console.log(&#39;start rendering&#39;);
        console.log(values);
        d3.select(this.target)
          // Get the old circles
          .selectAll(&#39;circle&#39;)
          .data(values)
          .enter()
          // For each new data point, append a circle to the target SVG
          .append(&#39;circle&#39;)
          // Apply several style attributes to the circle
          .attr(&#39;r&#39;, d => Math.log(d)) // 半径
          .attr(&#39;fill&#39;, &#39;#5fc&#39;) // 颜色
          .attr(&#39;stroke&#39;, &#39;#333&#39;) // 轮廓颜色
          .attr(&#39;transform&#39;, (d, i) => { // 移动位置
            var offset = i * 30 + 3 * Math.log(d);
            return `translate(${offset}, ${offset})`;
          });
      }
    
      destroy() {
        d3.select(this.target).selectAll(&#39;circle&#39;).remove();
      }
    }
    Nach dem Login kopieren
    Effektanzeige in index.html

    Ich habe das Obige für Sie zusammengestellt Ich hoffe, es wird Ihnen in Zukunft hilfreich sein.

    Verwandte Artikel:

    So implementieren Sie domänenübergreifende Cookies in Axios

    Es gibt Umgebungskonfigurationen für das JQuery-Plug-In im Webpack (Details zum Tutorial)

    So implementieren Sie eine Paging-Abfrage in Bootstrap4 + Vue2

    Das obige ist der detaillierte Inhalt vonSo implementieren Sie eine benutzerdefinierte Visualisierung mit AngularJS2, das in D3.js integriert ist. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Und
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