Задать вопрос
@nurdus

Можно ли не использовать getElementById во vue?

Есть поле 3 на 3 (div-ы). у каждой клетки есть координаты x и y.
Как сделать так чтобы при клике на клетку, соседние по краям клетки меняли цвет.

Сейчас у меня реализовано так (использую vue):
1) у каждой клетки id = 'x_y' и есть data-x, data-y;
2) при клике на div беру x и y и вычисляю координаты соседних клеток;
3) далее по ним (по координатам соседних клеток) нахожу id и меняю цвет.

Мне кажется, что не очень 'правильно' используя vue обращаться к getElementById.
  • Вопрос задан
  • 540 просмотров
Подписаться 1 Оценить 2 комментария
Решения вопроса 2
amux
@amux
alp.ac
Я бы реализовал с помощью простой матрицы, вместо цвета также можно принимать объект с множеством параметров {Цвет, размер и т.д.}
Например: https://jsfiddle.net/3tqmcg3a/2/
Ответ написан
Комментировать
kulakoff
@kulakoff Куратор тега Vue.js
Vue.js developing
Если не обращать внимание на разметку, у вас в шаблоне должно быть что-то вида:

<template v-for="cell in cells">
<cell :color="cell.color" @click="changeAround(cell)"></cell>
</template>


changeAround(cell) {
 // change cells color шт cells by using input cell

}


Смысл такой:
У вас есть массив клеток cells.
У вас есть компонент клетки и входной параметр у него - цвет.
При клике на cell вызывается обработчик, который вычисляет на основании данных клетки(порядковый номер, позиция) соседние клетки у которых нужно изменить цвет. Далее реактивно обновляется шаблон.
Ответ написан
Комментировать
Пригласить эксперта
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы