2017-08-29 46 views
0

需要一些幫助。無法實現條形圖團隊統計(不能將其添加到賴特的地方):d3條形圖團隊實施viewApp with angular 2

var team = []; 
     team = teams.teams; 
     for (var i = 0; i < team.length; i++) { 
      var dataset = []; 
      dataset = [team[i].spAchieved, team[i].spEstimated]; 
      // console.log(dataset); 

      var w = 100; 
      var h = 100; 
      var barPadding = 1; 

      var svg = d3.select("#chart") 
       .append("svg") 
       .attr("width", w) 
       .attr("height", h); 

      svg.selectAll("rect") 
       .data(dataset) 
       .enter() 
       .append("rect") 
       .attr("x", (d, i) => i * (w/dataset.length)) 
       .attr("y", d => h - d) 
       .attr("width", w/dataset.length - barPadding) 
       .attr("height", d => d) 
       .attr("fill", (d) => "rgb(100, 0, " + (d * 5) + ")"); 

      svg.selectAll("text") 
       .data(dataset) 
       .enter() 
       .append("text") 
       .text(d => d) 
       .attr("x", (d, i) => i * (w/dataset.length) + 15) 
       .attr("y", d => h - (d * 4) + 45); 
     }; 

和HTML:

<div class="jumbotron text-center" *ngIf="user"> 
<h1>TEAM View</h1> 

<div class="layer1"> 
    <a class="btn btn-primary" [routerLink]="['/profile']">{{user.name}}</a> 
</div> 
<div class="layer2"> 
    <a class="btn btn-primary" [routerLink]="['/addteam']">Add New Team</a> 
</div> 

<div id="chart"> 
<ul class="list-group" *ngFor="let newTeam of teams;"> 
    <div *ngFor="let team of newTeam;"> 
     <li class="list-group-item">Team Name: {{team.teamName}}</li> 
     <li class="list-group-item">Sprint Number: {{team.sprintNumber}}</li> 
     <li class="list-group-item">Completed At: {{team.completedAt}}</li> 
     <li class="list-group-item">Completed: {{team.completed}}</li> 
     <li class="list-group-item">SP Achieved: {{team.spAchieved}}</li> 
     <li class="list-group-item">SP Estimated: {{team.spEstimated}}</li> 
     <svg class="chart" #chart></svg> 
     <br/><br/> 
    </div> 
</ul> 
</div> 

就目前而言,其顯示的所有圖表中div,如果從id改爲body它顯示在底部,如果是li,那麼在標題中,我不能實現它到spAchievedspEstimated。謝謝

做一些改變,現在它在debuger中正確執行,但不要在執行結束時保存圖形。

現在的代碼如下所示:

import { Component, AfterViewInit, AfterContentInit } from '@angular/core'; 
import { AuthService } from '../../services/auth.service'; 
import { Router } from "@angular/router"; 

import * as d3 from "d3-selection"; // 

@Component({ 
    selector: 'app-dashboard', 
    templateUrl: './dashboard.component.html', 
    styleUrls: ['./dashboard.component.css'] 
}) 
export class DashboardComponent implements AfterViewInit, AfterContentInit { 
    user: Object; 
    teams: any; 
    //teamName: Object; 

constructor(
    private authService: AuthService, 
    private router: Router 
) { } 

ngAfterContentInit() { 
    this.authService.getProfile().subscribe(profile => { 
     this.user = profile.user; 
    }, 
     err => { 
      console.log(err); 
      return false; 
     }); 

    this.authService.getAllTeams().subscribe(teams => { 
     // console.log(teams); 
     this.teams = Object.keys(teams).map(key => teams[key]); 
     // console.log(this.teams); 
    }, 
     err => { 
      console.log(err); 
      return false; 
     }); 
} 

ngAfterViewInit() { 
    //Called after ngAfterContentInit when the component's view has been initialized. Applies to components only. 
    //Add 'implements AfterViewInit' to the class. 

    this.authService.getAllTeams().subscribe(teams => { 
     // console.log(teams); 
     this.teams = Object.keys(teams).map(key => teams[key]); 
     // console.log(this.teams); 

     const canvas =() => { 
      this.teams = Object.keys(teams).map(key => teams[key]); 
      var team = []; 
      team = teams.teams; 

      for (var i = 0; i < team.length; i++) { 
       var dataset = []; 
       dataset = [team[i].spAchieved, team[i].spEstimated]; 
       // dataset = 
       // console.log(dataset); 

       var w = 100; 
       var h = 100; 
       var barPadding = 1; 

       var j = 0; 
       // var svg = d3.select("#chart .list-element:nth-child(" + (i + 1) + ")") 
       // var svg = d3.select("li") 
       // console.log("#chart .list-element:nth-child(" + (i +1) +") .graph"); 
        var svg = d3.select("#chart .list-element:nth-child(" + (i+1) +") .graph")  
        .append("svg") 
        .attr("width", w) 
        .attr("height", h); 

       svg.selectAll("rect") 
        .data(dataset) 
        .enter() 
        .append("rect") 
        .attr("x", (d, i) => i * (w/dataset.length)) 
        .attr("y", d => h - d) 
        .attr("width", w/dataset.length - barPadding) 
        .attr("height", d => d) 
        .attr("fill", (d) => "rgb(100, 0, " + (d * 5) + ")"); 

       svg.selectAll("text") 
        .data(dataset) 
        .enter() 
        .append("text") 
        .text(d => d) 
        .attr("x", (d, i) => i * (w/dataset.length) + 15) 
        .attr("y", d => h - d); 
      }; 
     } 
     canvas(); 
    }, 
     err => { 
      console.log(err); 
      return false; 
     }); 
} 

}

和HTML

<div class="jumbotron text-center" *ngIf="user"> 
    <h1>TEAM View</h1> 

    <div class="layer1"> 
     <a class="btn btn-primary" [routerLink]="['/profile']">{{user.name}}</a> 
    </div> 
    <div class="layer2"> 
     <a class="btn btn-primary" [routerLink]="['/addteam']">Add New Team</a> 
    </div> 

    <div id="chart"> 
     <ul class="list-group" *ngFor="let newTeam of teams;"> 
      <div class="list-element" *ngFor="let team of newTeam;"> 
       <li class="list-group-item">Team Name: {{team.teamName}}</li> 
       <li class="list-group-item">Sprint Number: {{team.sprintNumber}}</li> 
       <li class="list-group-item">Completed At: {{team.completedAt}}</li> 
       <li class="list-group-item">Completed: {{team.completed}}</li> 
       <!-- <li class="list-group-item">SP Achieved: {{team.spAchieved}}</li> 
       <li class="list-group-item">SP Estimated: {{team.spEstimated}}</li> --> 
       <!-- <svg width="100" height="100" class="chart" #chart></svg> --> 
       <div class="graph"> 

       </div> 
       <br/><br/> 
      </div> 
     </ul> 
     <!-- --> 
    </div> 
</div> 

的問題,就目前而言,在執行D3代碼befor休息,所以我改變ngOnInit

回答

0

所以,我認爲有些東西在執行結束時重寫了頁面,我發現了什麼。現在,代碼看起來像這樣(我擦除功能canvas和再分配this.teams):

import { Component, AfterViewInit, AfterContentInit } from '@angular/core'; 
import { AuthService } from '../../services/auth.service'; 
import { Router } from "@angular/router"; 

import * as d3 from "d3-selection"; 

@Component({ 
    selector: 'app-dashboard', 
    templateUrl: './dashboard.component.html', 
    styleUrls: ['./dashboard.component.css'] 
}) 

export class DashboardComponent implements AfterViewInit, AfterContentInit { 
    user: Object; 
    teams: any; 

constructor(
    private authService: AuthService, 
    private router: Router 
) { } 

ngAfterContentInit() { 
    this.authService.getProfile().subscribe(profile => { 
     this.user = profile.user; 
    }, 
     err => { 
      console.log(err); 
      return false; 
     }); 

    this.authService.getAllTeams().subscribe(teams => { 
     // console.log(teams); 
     this.teams = Object.keys(teams).map(key => teams[key]); 
     // console.log(this.teams); 
    }, 
     err => { 
      console.log(err); 
      return false; 
     }); 
} 

ngAfterViewInit() { 
    this.authService.getAllTeams().subscribe(teams => { 
     // console.log(this.teams); 
     var team = []; 
     team = this.teams[0]; 

     for (var i = 0; i < team.length; i++) { 
      var dataset = []; 
      dataset = [team[i].spAchieved, team[i].spEstimated]; 
      // console.log(dataset); 

      var w = 100; 
      var h = 100; 
      var barPadding = 1; 

      var svg = d3.select("#chart .list-element:nth-child(" + (i + 1) + ") .graph") 
       .append("svg") 
       .attr("width", w) 
       .attr("height", h); 

      svg.selectAll("rect") 
       .data(dataset) 
       .enter() 
       .append("rect") 
       .attr("x", (d, i) => i * (w/dataset.length)) 
       .attr("y", d => h - d) 
       .attr("width", w/dataset.length - barPadding) 
       .attr("height", d => d) 
       .attr("fill", (d) => "rgb(100, 0, " + (d * 5) + ")"); 

      svg.selectAll("text") 
       .data(dataset) 
       .enter() 
       .append("text") 
       .text(d => d) 
       .attr("x", (d, i) => i * (w/dataset.length) + 15) 
       .attr("y", d => h - d); 
     }; 
    }, 
     err => { 
      console.log(err); 
      return false; 
     }); 
} 

}

現在它工作正常。也許它有助於某人。謝謝。