Home  >  Article  >  Web Front-end  >  How to implement custom visualization using AngularJS2 integrated with D3.js

How to implement custom visualization using AngularJS2 integrated with D3.js

亚连
亚连Original
2018-06-22 18:32:261558browse

This article mainly introduces the method of integrating ANGULAR2 and D3.js to achieve customized visualization. The editor thinks it is quite good, so I will share it with you now and give it as a reference. Let’s follow the editor and take a look.

This article introduces the method of integrating ANGULAR2 and D3.js to achieve customized visualization. I would like to share it with you. The details are as follows:

Goal

  1. Separation of presentation layer and logic layer

  2. Separation of data and visual components

  3. Two-way binding of data and view, real-time Update

  4. The code structure is clear and easy to maintain and modify

Basic principles

Components of angular2 Life cycle hook method\parent-child component interaction mechanism\template syntax

Source code analysis

The code structure is very simple, except for the homepage index.html and main.ts The code structure is as follows:

Code structure

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 { }

app.component.html

Implement host view definition,

2 buttons, the button can be bound to 2 click events, perform corresponding actions, refresh the array, and complete the update of the bubble chart at the same time;

1 A bubble chart sub-component, where values ​​is the input attribute of the sub-component to realize communication between parent and child components, numArray is the input data array of the bubble chart, and the subsequent is a randomly generated array

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

app.component .ts

Refresh the data by specifying a timer that refreshes every 3 seconds. Note here that you need to clear the array first and then add elements. If you directly modify the array element value without changing the reference, the bubble cannot be refreshed. Figure

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();
 }
}

bubbles.component.ts Bubble chart component class

  1. ngOnChanges() life cycle method can be automatically called when the input attribute values ​​change;

  2. @ViewChild can get a reference to the child element svg, where the #target custom variable is used to identify the svg child element

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);
    }
}

bubbles. chart.ts bubble chart class

  1. d3.js syntax-defined bubble chart class, with a drawing method and erasing method

  2. Need to introduce bd36a97ef732e252716ac5494b5d06f62cacc6d41bbb37262a98f745aa00fbf0

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();
  }
}

Effect display# in index.html

##The above is what I compiled for everyone. I hope it will be helpful to everyone in the future.

Related articles:

How to implement cookie cross-domain in axios

In webpack, there is the environment configuration of jquery plug-in (details Tutorial)

How to implement paging query in Bootstrap4 Vue2

The above is the detailed content of How to implement custom visualization using AngularJS2 integrated with D3.js. For more information, please follow other related articles on the PHP Chinese website!

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn