#javascript
Вопрос:
Я уверен, что есть способ написать более короткую версию следующего js-кода. В конце концов, я просто повторяюсь снова и снова. Есть какие-нибудь предложения?
Большое спасибо!
if (designVal == 0 amp;amp; colorVal == 0) {
design01yellow.style.display = "block";
design01black.style.display = "none";
design01blue.style.display = "none";
design01grey.style.display = "none";
design02yellow.style.display = "none";
design02black.style.display = "none";
design02blue.style.display = "none";
design02grey.style.display = "none";
design03yellow.style.display = "none";
design03black.style.display = "none";
design03blue.style.display = "none";
design03grey.style.display = "none";
} else if (designVal == 0 amp;amp; colorVal == 1) {
design01yellow.style.display = "none";
design01black.style.display = "block";
design01blue.style.display = "none";
design01grey.style.display = "none";
design02yellow.style.display = "none";
design02black.style.display = "none";
design02blue.style.display = "none";
design02grey.style.display = "none";
design03yellow.style.display = "none";
design03black.style.display = "none";
design03blue.style.display = "none";
design03grey.style.display = "none";
} else if (designVal == 0 amp;amp; colorVal == 2) {
design01yellow.style.display = "none";
design01black.style.display = "none";
design01blue.style.display = "block";
design01grey.style.display = "none";
design02yellow.style.display = "none";
design02black.style.display = "none";
design02blue.style.display = "none";
design02grey.style.display = "none";
design03yellow.style.display = "none";
design03black.style.display = "none";
design03blue.style.display = "none";
design03grey.style.display = "none";
} else if
///AND SO ON
Комментарии:
1. создание данных на основе файлов json
2. Я бы поместил класс типа «желтый» «синий» на какой-нибудь родительский элемент, а затем CSS все остальное.
3. Вы могли бы просто нормализовать все до «нет», а затем изменить только то, которое вы хотите установить на «блокировать»?
Ответ №1:
Дайте всем элементам общий класс (например class="design"
). Пройдите по ним, установив для них все значения none
, а затем установите для конкретного элемента значение block
.
document.querySelectorAll(".design").forEach(el => el.style.display = "none");
if (designVal == 0 amp;amp; colorVal == 0) {
design01yellow.style.display = "block";
} else if (designVal == 0 amp;amp; colorVal == 1) {
design01black.style.display = "block";
} ...
Ответ №2:
Я бы нормализовал их до «отображение: нет», а затем установил только тот, который вы хотите display: block
.
if (designVal === 0) {
design01yellow.style.display = "none";
design01black.style.display = "none";
design01blue.style.display = "none";
design01grey.style.display = "none";
design02yellow.style.display = "none";
design02black.style.display = "none";
design02blue.style.display = "none";
design02grey.style.display = "none";
design03yellow.style.display = "none";
design03black.style.display = "none";
design03blue.style.display = "none";
design03grey.style.display = "none";
if(colorVal === 0) {
design01yellow.style.display = "block";
} else if (colorVal === 1) {
design01black.style.display = "block";
} else if (colorVal === 2) {
design01blue.style.display = "block";
}
// and so on
}