freeCodeCamp/curriculum/challenges/chinese-traditional/04-data-visualization/data-visualization-with-d3/add-attributes-to-the-circl...

5.4 KiB
Raw Blame History

id title challengeType forumTopicId dashedName
587d7fab367417b2b2512bd8 給 Circle 元素添加屬性 6 301471 add-attributes-to-the-circle-elements

--description--

上個挑戰爲 dataset 中的每個點都創建了 circle 元素,並將它們添加到 SVG 畫布上。 但是 D3 需要更多關於位置和 circle 大小的信息來正確地顯示它們。

在 SVG 中 circle 有三個主要的屬性。 cxcy 屬性是座標。 它們告訴 D3 將圖形的中心放在 SVG 畫布的何處。 半徑( r 屬性)給出 circle 的大小。

recty 座標一樣,circlecy 屬性是從 SVG 畫布的頂端開始測量的,而不是從底端。

所有的屬性都可以用回調函數來動態設值。 記住,所有串聯在 data(dataset) 後面的方法會爲 dataset 中的每個對象都運行一次。 回調函數中的 d 參數指在 dataset 中的當前對象,對每個點來說都是一個數組。 你可以使用方括號的方式,如 d[0],來訪問數組中的值。

--instructions--

circle 元素添加 cxcyr 屬性。 cx 的值應該是 dataset 中每個對象的數組的第一個數, cy 的值應該根據數組中的第二個值,但是要確保正向顯示圖表而不是倒轉。 所有 circle 的 r 值應爲 5

--hints--

你應該有 10 個 circle 元素。

assert($('circle').length == 10);

第一個 circle 元素的 cx 值應爲 34cy 值應爲 422r 值應爲 5

assert(
  $('circle').eq(0).attr('cx') == '34' &&
    $('circle').eq(0).attr('cy') == '422' &&
    $('circle').eq(0).attr('r') == '5'
);

第二個 circle 元素的 cx 值應爲 109cy 值應爲 220r 值應爲 5

assert(
  $('circle').eq(1).attr('cx') == '109' &&
    $('circle').eq(1).attr('cy') == '220' &&
    $('circle').eq(1).attr('r') == '5'
);

第三個 circle 元素的 cx 值應爲 310cy 值應爲 380 r 值應爲 5

assert(
  $('circle').eq(2).attr('cx') == '310' &&
    $('circle').eq(2).attr('cy') == '380' &&
    $('circle').eq(2).attr('r') == '5'
);

第四個 circle 元素的 cx 值應爲 79cy 值應爲 89r 值應爲 5

assert(
  $('circle').eq(3).attr('cx') == '79' &&
    $('circle').eq(3).attr('cy') == '89' &&
    $('circle').eq(3).attr('r') == '5'
);

第五個 circle 元素的 cx 值應爲 420cy 值應爲 280r 值應爲 5

assert(
  $('circle').eq(4).attr('cx') == '420' &&
    $('circle').eq(4).attr('cy') == '280' &&
    $('circle').eq(4).attr('r') == '5'
);

第六個 circle 元素的 cx 值應爲 233cy 值應爲 355r 值應爲 5

assert(
  $('circle').eq(5).attr('cx') == '233' &&
    $('circle').eq(5).attr('cy') == '355' &&
    $('circle').eq(5).attr('r') == '5'
);

第七個 circle 元素的 cx 值應爲 333cy 值應爲 404r 值應爲 5

assert(
  $('circle').eq(6).attr('cx') == '333' &&
    $('circle').eq(6).attr('cy') == '404' &&
    $('circle').eq(6).attr('r') == '5'
);

第八個 circle 元素的 cx 值應爲 222cy 值應爲 167 r 值應爲 5

assert(
  $('circle').eq(7).attr('cx') == '222' &&
    $('circle').eq(7).attr('cy') == '167' &&
    $('circle').eq(7).attr('r') == '5'
);

第九個 circle 元素的 cx 值應爲 78cy 值應爲 180r 值應爲 5

assert(
  $('circle').eq(8).attr('cx') == '78' &&
    $('circle').eq(8).attr('cy') == '180' &&
    $('circle').eq(8).attr('r') == '5'
);

第十個 circle 元素的 cx 值應爲 21cy 值應爲 377r 值應爲 5

assert(
  $('circle').eq(9).attr('cx') == '21' &&
    $('circle').eq(9).attr('cy') == '377' &&
    $('circle').eq(9).attr('r') == '5'
);

--seed--

--seed-contents--

<body>
  <script>
    const dataset = [
                  [ 34,    78 ],
                  [ 109,   280 ],
                  [ 310,   120 ],
                  [ 79,    411 ],
                  [ 420,   220 ],
                  [ 233,   145 ],
                  [ 333,   96 ],
                  [ 222,   333 ],
                  [ 78,    320 ],
                  [ 21,    123 ]
                ];


    const w = 500;
    const h = 500;

    const svg = d3.select("body")
                  .append("svg")
                  .attr("width", w)
                  .attr("height", h);

    svg.selectAll("circle")
       .data(dataset)
       .enter()
       .append("circle")
       // Add your code below this line



       // Add your code above this line

  </script>
</body>

--solutions--

<body>
  <script>
    const dataset = [
                  [ 34,    78 ],
                  [ 109,   280 ],
                  [ 310,   120 ],
                  [ 79,    411 ],
                  [ 420,   220 ],
                  [ 233,   145 ],
                  [ 333,   96 ],
                  [ 222,   333 ],
                  [ 78,    320 ],
                  [ 21,    123 ]
                ];


    const w = 500;
    const h = 500;

    const svg = d3.select("body")
                  .append("svg")
                  .attr("width", w)
                  .attr("height", h);

    svg.selectAll("circle")
       .data(dataset)
       .enter()
       .append("circle")
       .attr("cx", (d) => d[0])
       .attr("cy", (d) => h - d[1])
       .attr("r", 5)

  </script>
</body>