D3: График не отображает оси X и Y - PullRequest
0 голосов
/ 02 марта 2019

У меня есть проект d3, но я не могу правильно отобразить оси x и y.Он отображает только первые 2 числа на оси Y и все.Кто-нибудь может мне помочь, почему это не отображается.Что мне здесь не хватает?

это код:

loadData = ()=> {
  req = new XMLHttpRequest();
  req.open("GET", "https://raw.githubusercontent.com/freeCodeCamp/ProjectReferenceData/master/GDP-data.json" , true);
  req.send();
  req.onload= ()=>{
      json = JSON.parse(req.responseText);
      //create measurements
      const margin = 60
      const width = 1000 - margin;
      const height = 600 - margin;

      //create svg
      const svg = d3.select("svg");
      const chart = svg.append("g")
        .attr("transform", `translate(${margin}, ${margin})`);


      //y-axis: split charts into 2 equal parts using scaling function
      const yScale = d3.scaleLinear()
        .range([height, 0]) //length
        .domain([0,100]); //content

      //create x-axis
      const yAxis = d3.axisLeft(yScale);

      //append y-axis
      chart.append("g")
        .call(yAxis);

       //create x-scale
      const xScale = d3.scaleBand()
        .range([0, width]) //length
        .domain([0,100]) //content
        .padding(0.2);

      //create x-axis
      const xAxis = d3.axisBottom(xScale);

      //append x-axis
      chart.append("g")
        .attr(`transform`, `translate(0, ${height})`)
        .call(xAxis);
   } 
}

loadData();

Это мой кодовый блок: codepen

1 Ответ

0 голосов
/ 02 марта 2019

Вы работаете с размером панели w1000, h600 (+ поле).Измените размер вашего SVG-элемента (в CSS) соответственно, и диаграмма будет отображаться, как и ожидалось:

svg {
  width: 1030px;
  height: 630px;
}

PS: В качестве альтернативы установите размер svg в вашем коде JS, таким образом, вы должны определить эти числа только в одном месте..

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...