Files

152 lines
5.4 KiB
Markdown
Raw Permalink Normal View History

---
id: 587d7fa9367417b2b2512bce
title: Динамічне налаштування координат для кожної панелі
challengeType: 6
forumTopicId: 301487
dashedName: dynamically-set-the-coordinates-for-each-bar
---
# --description--
Останнє завдання створило та додало прямокутник до елементу `svg` для кожної точки в`dataset`, щоб зобразити панель. На жаль, усі вони склались у стовпець один на одного.
Атрибути `x` та `y` керують розміщенням прямокутника. Вони повідомляють D3, де починати малювати фігуру в зоні `svg`. Останнє завдання розміщує їх усіх до 0 таким чином, щоб кожен стовпчик розташовувався у верхньому лівому кутку.
У стовпчиковій діаграмі всі стовпці повинні розташовуватись на однаковому вертикальному рівні, тобто значення `y` лишається незмінним (на 0) для усіх стовпців. Однак, при додаванні нових стовпців значення `x` потрібно змінювати. Пам'ятайте, що більші значення `x` зміщують елементи праворуч. Значення`x` повинно зростати при перегляді масиву елементів у `dataset`.
Метод `attr()` у D3 приймає функцію зворотнього зв'язку до цього динамічно встановленого атрибуту. Функція зворотнього зв'язку приймає два аргументи: один для самої точки даних (зазвичай `d`) та один для індексу точки даних у масиві. Другий аргумент для індексу - необов'язковий. Ось такий формат:
```js
selection.attr("property", (d, i) => {
})
```
Варто зауважити, що НЕ потрібно писати цикл `for` або використовувати `forEach()` для повторення елементів у наборі даних. Нагадаємо, що метод `data()` аналізує набір даних, і що будь-який інший метод, вказаний після `data()`, запускається одноразово для кожного елемента в наборі даних.
# --instructions--
Змініть атрибут `x` функції зворотнього зв'язку таким чином, щоб він повернув індекс на 30.
**Примітка:** Ширина кожного елементу 25, тому збільшіть значення кожного `x` на 30, додавши пробіли між елементами. Будь-яке значення, більше 25, спрацювало б за таким же принципом.
# --hints--
Перший `rect` повинен мати `0` значенням `x`.
```js
assert($('rect').eq(0).attr('x') == '0');
```
Другий `rect` повинен мати `x` значенням `30`.
```js
assert($('rect').eq(1).attr('x') == '30');
```
Третій `rect` повинен мати `x` значенням `60`.
```js
assert($('rect').eq(2).attr('x') == '60');
```
Четвертий `rect` повинен мати `x` значенням `90`.
```js
assert($('rect').eq(3).attr('x') == '90');
```
П'ятий `rect` повинен мати `x` значенням `120`.
```js
assert($('rect').eq(4).attr('x') == '120');
```
Шостий `rect` повинен мати `x` значенням `150`.
```js
assert($('rect').eq(5).attr('x') == '150');
```
Сьомий `rect` повинен мати `x` повинен мати `180`.
```js
assert($('rect').eq(6).attr('x') == '180');
```
Восьмий `rect` повинен мати `x` значенням `210`.
```js
assert($('rect').eq(7).attr('x') == '210');
```
Дев'ятий `rect` повинен мати `x` значенням `240`.
```js
assert($('rect').eq(8).attr('x') == '240');
```
# --seed--
## --seed-contents--
```html
<body>
<script>
const dataset = [12, 31, 22, 17, 25, 18, 29, 14, 9];
const w = 500;
const h = 100;
const svg = d3.select("body")
.append("svg")
.attr("width", w)
.attr("height", h);
svg.selectAll("rect")
.data(dataset)
.enter()
.append("rect")
.attr("x", (d, i) => {
// Add your code below this line
// Add your code above this line
})
.attr("y", 0)
.attr("width", 25)
.attr("height", 100);
</script>
</body>
```
# --solutions--
```html
<body>
<script>
const dataset = [12, 31, 22, 17, 25, 18, 29, 14, 9];
const w = 500;
const h = 100;
const svg = d3.select("body")
.append("svg")
.attr("width", w)
.attr("height", h);
svg.selectAll("rect")
.data(dataset)
.enter()
.append("rect")
.attr("x", (d, i) => {
return i * 30
})
.attr("y", 0)
.attr("width", 25)
.attr("height", 100);
</script>
</body>
```