5.4 KiB
id, title, challengeType, forumTopicId, dashedName
id | title | challengeType | forumTopicId | dashedName |
---|---|---|---|---|
587d7fa9367417b2b2512bce | Динамічне налаштування координат для кожної панелі | 6 | 301487 | dynamically-set-the-coordinates-for-each-bar |
--description--
Останнє завдання створило та додало прямокутник до елементу svg
для кожної точки вdataset
, щоб зобразити панель. На жаль, усі вони склались у стовпець один на одного.
Атрибути x
та y
керують розміщенням прямокутника. Вони повідомляють D3, де починати малювати фігуру в зоні svg
. Останнє завдання розміщує їх усіх до 0 таким чином, щоб кожен стовпчик розташовувався у верхньому лівому кутку.
У стовпчиковій діаграмі всі стовпці повинні розташовуватись на однаковому вертикальному рівні, тобто значення y
лишається незмінним (на 0) для усіх стовпців. Однак, при додаванні нових стовпців значення x
потрібно змінювати. Пам'ятайте, що більші значення x
зміщують елементи праворуч. Значенняx
повинно зростати при перегляді масиву елементів у dataset
.
Метод attr()
у D3 приймає функцію зворотнього зв'язку до цього динамічно встановленого атрибуту. Функція зворотнього зв'язку приймає два аргументи: один для самої точки даних (зазвичай d
) та один для індексу точки даних у масиві. Другий аргумент для індексу - необов'язковий. Ось такий формат:
selection.attr("property", (d, i) => {
})
Варто зауважити, що НЕ потрібно писати цикл for
або використовувати forEach()
для повторення елементів у наборі даних. Нагадаємо, що метод data()
аналізує набір даних, і що будь-який інший метод, вказаний після data()
, запускається одноразово для кожного елемента в наборі даних.
--instructions--
Змініть атрибут x
функції зворотнього зв'язку таким чином, щоб він повернув індекс на 30.
Примітка: Ширина кожного елементу 25, тому збільшіть значення кожного x
на 30, додавши пробіли між елементами. Будь-яке значення, більше 25, спрацювало б за таким же принципом.
--hints--
Перший rect
повинен мати 0
значенням x
.
assert($('rect').eq(0).attr('x') == '0');
Другий rect
повинен мати x
значенням 30
.
assert($('rect').eq(1).attr('x') == '30');
Третій rect
повинен мати x
значенням 60
.
assert($('rect').eq(2).attr('x') == '60');
Четвертий rect
повинен мати x
значенням 90
.
assert($('rect').eq(3).attr('x') == '90');
П'ятий rect
повинен мати x
значенням 120
.
assert($('rect').eq(4).attr('x') == '120');
Шостий rect
повинен мати x
значенням 150
.
assert($('rect').eq(5).attr('x') == '150');
Сьомий rect
повинен мати x
повинен мати 180
.
assert($('rect').eq(6).attr('x') == '180');
Восьмий rect
повинен мати x
значенням 210
.
assert($('rect').eq(7).attr('x') == '210');
Дев'ятий rect
повинен мати x
значенням 240
.
assert($('rect').eq(8).attr('x') == '240');
--seed--
--seed-contents--
<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--
<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>