


How to implement custom visualization using AngularJS2 integrated with D3.js
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
Separation of presentation layer and logic layer
Separation of data and visual components
Two-way binding of data and view, real-time Update
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 '@angular/core'; @Component({ selector: 'app-root', templateUrl: './app.component.html', styleUrls: ['./app.component.css'] }) export class AppComponent implements OnInit, OnDestroy { intervalId = 0; numArray = []; // 清除定时器 private clearTimer() { console.log('stop refreshing'); 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
ngOnChanges() life cycle method can be automatically called when the input attribute values change;
@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 '@angular/core'; import {BubblesChart} from './bubbles.chart'; declare var d3; @Component({ selector: 'bubbles', template: '<svg #target width="900" height="300"></svg>', }) export class Bubbles implements OnChanges, AfterViewInit { @Input() values: number[]; chart: BubblesChart; @ViewChild('target') 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
d3.js syntax-defined bubble chart class, with a drawing method and erasing method
Need to introduce
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('start rendering'); console.log(values); d3.select(this.target) // Get the old circles .selectAll('circle') .data(values) .enter() // For each new data point, append a circle to the target SVG .append('circle') // Apply several style attributes to the circle .attr('r', d => Math.log(d)) // 半径 .attr('fill', '#5fc') // 颜色 .attr('stroke', '#333') // 轮廓颜色 .attr('transform', (d, i) => { // 移动位置 var offset = i * 30 + 3 * Math.log(d); return `translate(${offset}, ${offset})`; }); } destroy() { d3.select(this.target).selectAll('circle').remove(); } }
Effect display# in index.html
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!

Hot AI Tools

Undress AI Tool
Undress images for free

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

The scope of JavaScript determines the accessibility scope of variables, which are divided into global, function and block-level scope; the context determines the direction of this and depends on the function call method. 1. Scopes include global scope (accessible anywhere), function scope (only valid within the function), and block-level scope (let and const are valid within {}). 2. The execution context contains the variable object, scope chain and the values of this. This points to global or undefined in the ordinary function, the method call points to the call object, the constructor points to the new object, and can also be explicitly specified by call/apply/bind. 3. Closure refers to functions accessing and remembering external scope variables. They are often used for encapsulation and cache, but may cause

There is an essential difference between JavaScript's WebWorkers and JavaThreads in concurrent processing. 1. JavaScript adopts a single-thread model. WebWorkers is an independent thread provided by the browser. It is suitable for performing time-consuming tasks that do not block the UI, but cannot operate the DOM; 2. Java supports real multithreading from the language level, created through the Thread class, suitable for complex concurrent logic and server-side processing; 3. WebWorkers use postMessage() to communicate with the main thread, which is highly secure and isolated; Java threads can share memory, so synchronization issues need to be paid attention to; 4. WebWorkers are more suitable for front-end parallel computing, such as image processing, and

CompositionAPI in Vue3 is more suitable for complex logic and type derivation, and OptionsAPI is suitable for simple scenarios and beginners; 1. OptionsAPI organizes code according to options such as data and methods, and has clear structure but complex components are fragmented; 2. CompositionAPI uses setup to concentrate related logic, which is conducive to maintenance and reuse; 3. CompositionAPI realizes conflict-free and parameterizable logical reuse through composable functions, which is better than mixin; 4. CompositionAPI has better support for TypeScript and more accurate type derivation; 5. There is no significant difference in the performance and packaging volume of the two; 6.

Initialize the project and create package.json; 2. Create an entry script index.js with shebang; 3. Register commands through bin fields in package.json; 4. Use yargs and other libraries to parse command line parameters; 5. Use npmlink local test; 6. Add help, version and options to enhance the experience; 7. Optionally publish through npmpublish; 8. Optionally achieve automatic completion with yargs; finally create practical CLI tools through reasonable structure and user experience design, complete automation tasks or distribute widgets, and end with complete sentences.

Use document.createElement() to create new elements; 2. Customize elements through textContent, classList, setAttribute and other methods; 3. Use appendChild() or more flexible append() methods to add elements to the DOM; 4. Optionally use insertBefore(), before() and other methods to control the insertion position; the complete process is to create → customize → add, and you can dynamically update the page content.

Microfrontendssolvescalingchallengesinlargeteamsbyenablingindependentdevelopmentanddeployment.1)Chooseanintegrationstrategy:useModuleFederationinWebpack5forruntimeloadingandtrueindependence,build-timeintegrationforsimplesetups,oriframes/webcomponents

TypeScript's advanced condition types implement logical judgment between types through TextendsU?X:Y syntax. Its core capabilities are reflected in the distributed condition types, infer type inference and the construction of complex type tools. 1. The conditional type is distributed in the bare type parameters and can automatically split the joint type, such as ToArray to obtain string[]|number[]. 2. Use distribution to build filtering and extraction tools: Exclude excludes types through TextendsU?never:T, Extract extracts commonalities through TextendsU?T:Never, and NonNullable filters null/undefined. 3

To get the length of a JavaScript array, you can use the built-in length property. 1. Use the .length attribute to return the number of elements in the array, such as constfruits=['apple','banana','orange'];console.log(fruits.length);//Output: 3; 2. This attribute is suitable for arrays containing any type of data such as strings, numbers, objects, or arrays; 3. The length attribute will be automatically updated, and its value will change accordingly when elements are added or deleted; 4. It returns a zero-based count, and the length of the empty array is 0; 5. The length attribute can be manually modified to truncate or extend the array,
