Форум программистов, компьютерный форум, киберфорум
JavaScript для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.60/5: Рейтинг темы: голосов - 5, средняя оценка - 4.60
0 / 0 / 0
Регистрация: 22.11.2015
Сообщений: 23

Можно ли сделать это одной функцией?

05.03.2020, 22:31. Показов 1100. Ответов 4
Метки js (Все метки)

Студворк — интернет-сервис помощи студентам
Написал такой код, можно его как-то записать компактнее??

JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
const getId = id => document.getElementById(id);
 
let check = true;
 
getId('blockColor').onclick = function(){
    if(check){
        this.style.color = 'red';
        check = false;
    }
    else{
        this.style.color = '';
        check = true;
    }
}
 
getId('blockColor1').onclick = function(){
    if(check){
        this.style.color = 'yellow';
        check = false;
    }
    else{
        this.style.color = '';
        check = true;
    }
}
 
getId('blockColor2').onclick = function(){
    if(check){
        this.style.color = 'green';
        check = false;
    }
    else{
        this.style.color = '';
        check = true;
    }
}
 
getId('blockColor3').onclick = function(){
    if(check){
        this.style.color = 'blue';
        check = false;
    }
    else{
        this.style.color = '';
        check = true;
    }
}
 
getId('blockColor4').onclick = function(){
    if(check){
        this.style.color = 'orange';
        check = false;
    }
    else{
        this.style.color = '';
        check = true;
    }
}
 
getId('blockColor5').onclick = function(){
    if(check){
        this.style.color = 'gray';
        check = false;
    }
    else{
        this.style.color = '';
        check = true;
    }
}
HTML5
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <link rel="stylesheet" href="style.css">
    <title>Document</title>
</head>
<body>
        <ol>
            <li id="blockColor">Red</li>
            <li id="blockColor1">Yellow</li>
            <li id="blockColor2">Green</li>
            <li id="blockColor3">Blue</li>
            <li id="blockColor4">Orange</li>
            <li id="blockColor5">Gray</li>
        </ol>
    <script src="main.js"></script>
</body>
</html>
CSS
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
* {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}
body{
  margin-top: 18vh;
}
 
#blockColor, #blockColor1, #blockColor2, #blockColor3, #blockColor4, #blockColor5{
    font-size: 60px;
    margin-bottom: 15px;
    margin-left: 40%;
    cursor: pointer;  
}
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
05.03.2020, 22:31
Ответы с готовыми решениями:

Что это такое и как это можно сделать?
Это что то из стандартных компонентов или как в своем проекте сделать что то подобное? подразумевается пока не нажал окно скрыто, нажал,...

можно ли в с++ вызвать переменную из одной функции в другую т.е. мы переменну задали в одной функции а использовали в другой... и как это реализовать?
можно ли в с++ вызвать переменную из одной функции в другую т.е. мы переменну задали в одной функции а использовали в другой... и как это...

Как сделать чтоб все проверки вызывались одной функцией?
Доброго времени суток! Имеется код с огромным числом вот таких проверок: cout &lt;&lt; &quot;\nEnter number (-100000 to 100000):...

4
Эксперт JS
 Аватар для DrType
6553 / 3624 / 1075
Регистрация: 07.09.2019
Сообщений: 5,877
Записей в блоге: 1
05.03.2020, 23:10
JavaScript
1
2
3
4
for(let b of document.querySelectorAll('ol li')){b.onclick=function(){
    if(check){this.style.color = this.textContent;
    check = false;}
    else{this.style.color = '';check = true;}}}
1
Эксперт JS
6497 / 3908 / 2006
Регистрация: 14.06.2018
Сообщений: 6,781
05.03.2020, 23:13
Лучший ответ Сообщение было отмечено tarabar1 как решение

Решение

tarabar1, там и поведение хулиганило.
JavaScript
1
2
3
4
5
6
for (let li of document.querySelectorAll("ol li"))
    li.onclick = li_click;
function li_click() {
    let color = this.textContent.toLowerCase();
    this.style.color = this.style.color === color ? "" : color;
}
1
Эксперт JS
 Аватар для DrType
6553 / 3624 / 1075
Регистрация: 07.09.2019
Сообщений: 5,877
Записей в блоге: 1
05.03.2020, 23:25
А если ТС для только для примера сделал названия цветов в пунктах списка? Тогда затея с textContent никуда не годится.
1
0 / 0 / 0
Регистрация: 22.11.2015
Сообщений: 23
05.03.2020, 23:30  [ТС]
Ну это понятно. Но все так, такая задача была с названиями цветов) Спасибо, не додумался бы сам, что можно так реализовать
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
05.03.2020, 23:30
Помогаю со студенческими работами здесь

нужно создать таблицу из 3 строк и 4 столбцов и заполнить её (любой информацией,это неважно) . Как это можно сделать ?
Здравствуйте.У меня возникла проблема. Помогите пожалуйста!Модуль в понедельник , про таблицы ничего не рассказывали , а преподаватель...

Можно ли на планшете вместо 8ки поставить 7ку? Как это можно сделать?
Здравствуйте! Такой вот вопросик: Кто-то сталкивался с переустановкой винды на планшетах? Если да, то возможно ли это? И что нужно делать,...

Как можно восстановить данные, если они вдруг куда-либо исчезли и можно ли это сделать
Помогите, если кто-нибудь знает как восстановить данные, подскажите, у меня пропала очень важная папка с рабочего стола, куда не понятно ,...

Элементы комбинаторики. Надо разослать 6 срочных писем. Сколькими способами это можно сделать, если любое письмо можно отправить с любым из 3 курьеров
Надо разослать 6 срочных писем. Сколькими способами это можно сделать, если любое письмо можно отправить с любым из 3 курьеров?

можно ли сделать это в D5?
Задача: табл. с полями: название графика, метка выбора(boolean). Название каждого графика должно быть уникального цвета. По этому цвету...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
Очистка реквизитов документа при копировании
Maks 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях. Задача: при копировании документа очищать определенные реквизиты и табличную. . .
модель ЗдравоСохранения 8. Подготовка к разному выполнению заданий
anaschu 08.04.2026
https:/ / github. com/ shumilovas/ med2. git main ветка * содержимое блока дэлэй из старой модели теперь внутри зайца новой модели 8ATzM_2aurI
Блокировка документа от изменений, если он открыт у другого пользователя
Maks 08.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в конфигурации КА2. Задача: запретить редактирование документа, если он открыт у другого пользователя. / / . . .
Система безопасности+живучести для сервера-слоя интернета (сети). Двойная привязка.
Hrethgir 08.04.2026
Далее были размышления о системе безопасности. Сообщения с наклонным текстом - мои. А как нам будет можно проверить, что ссылка наша, а не подделана хулиганами, которая выбросит на другую ветку и. . .
Модель ЗдрввоСохранения 7: больше работников, больше ресурсов.
anaschu 08.04.2026
работников и заданий может быть сколько угодно, но настроено всё так, что используется пока что только 20% kYBz3eJf3jQ
Дальние перспективы сервера - слоя сети с космологическим дизайном интефейса карты и логики.
Hrethgir 07.04.2026
Дальнейшее ближайшее планирование вывело к размышлениям над дальними перспективами. И вот тут может быть даже будут нужны оценки специалистов, так как в дальних перспективах всё может очень сильно. . .
Горе от ума
kumehtar 07.04.2026
Эта мне ментальная установка, что вот прямо сейчас, мол, мне для полного счастья не хватает (нужное вписать), и когда я этого достигну - тогда и полный кайф. Одна из самых сильных ловушек на пути. . . .
Использование значений реквизитов справочника в документе, с определенными условиями и правами
Maks 07.04.2026
1. Контроль срока действия договора Алгоритм из решения ниже реализован на примере нетипового документа "ЗаявкаНаРаботу", разработанного в конфигурации КА2. Задача: уведомлять пользователя, если. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru