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

Смена текста в зависимости от дня недели и времени

18.10.2014, 21:32. Показов 29037. Ответов 49
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Всем доброго дня.

Есть необходимость выводить текст в зависимости от дня недели и времени что то вроде Расписания.

нашел как вывести по дням недели:

JavaScript
1
2
3
4
5
now = new Date()
  if (now.getDay() == 0)
    document.write("Воскресенье")
  if (now.getDay() == 1)
    document.write("Понедельник")
и тд..

Нашел как сделать по времени:

JavaScript
1
2
3
4
5
var h=(new Date()).getHours();                  
if (h > 3 && h <  12) document.writeln("Доброе утро");                    
if (h > 11 && h <  19) document.writeln("Добрый день");                   
if (h > 18 && h <  24) document.writeln("Добрый вечер");                 
if (h > 23 || h <  4 ) document.writeln("Привет полуночникам");
А вот как это вместе скрутить, что-бы в воскресенье в 9 часов один текст выводился, а в понедельник в 9 другой,
не знаю.

Может кто мне помочь?

С уважением Денис.
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
18.10.2014, 21:32
Ответы с готовыми решениями:

Расписание занятий в зависимости от дня недели
Привет всем! Хотел бы узнать как это реализовать: Есть сайт определенной специальности, в специальном блоке должно отображаться расписание...

Автоматическое заполнение ячеек, в зависимости от дня недели
Добрый день! Помогите довести формулу до ума! Есть табель учёта рабочего времени, необходимо, что бы при смене месяца в ячейке В1,...

Вывод сообщения в зависимости от введенного дня недели
Написать программу, которая запрашивает у пользователя номера дня недели и выводит одно из сообщений : &quot;Рабочий день&quot;,...

49
0 / 0 / 0
Регистрация: 18.10.2014
Сообщений: 23
21.10.2014, 17:34  [ТС]
Студворк — интернет-сервис помощи студентам
Итак итоги:

РЕСПЕКТ и УВАЖУХА реальным программистам and_y87 и Kloks.

В результате творческой работы имеем рабочий скрипт, который выводит в зависимости от дня недели пн,вт, ...
и в зависимости от времени суток, необходимый текст. Текст обновляется через нужный промежуток времени.
Это сделано для того чтобы у пользователя отображалась актуальная информация без перезагрузки страницы.
Допустим в 8.50 пользователь зашел на сайт отображается "текст 1", а в 9.00 уже "текст 2", при этом пользователь страницу не обновляет.



Кликните здесь для просмотра всего текста

Подключаем внешний файл .js в котором у нас база с расписанием.
HTML5
1
<script src="../12.js" type="text/javascript"></script>
Определяем DIV в который будем выводить информацию из .js файла
HTML5
1
<div id='raspisanie'></div>
Далее скрипт обработки данных из .js файла.

HTML5
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
<script type="text/javascript">
                 
                 
(function(){
    function getEventByDay( base, day, hour )
   {
      var obj = base[day],
      len = obj.length;
 
      for ( var i=0; i < len; i++ )
      {
         var resp = obj[i];
         if ( hour >= resp[0] && hour < resp[1] ) break;
      }
      return resp;
   }
         // Функция получает into, БазуДанных и необходимые данные подставляет в into
   function setupEvent( into, base )
   {
      var d = new Date(),
      day = d.getDay(),
      h = d.getHours(),
      resp = 'n/a';
 
      var data = getEventByDay(base, day, h);
           // тут можно изменить шрифт, цвет берется из файла .js
      resp = '<p><font color=' + data[2] + '>' + data[3] + '</font></p>';
 
      document.getElementById( into ).innerHTML=resp;
   }
 
          // Вызываем...
   setupEvent( 'raspisanie', data );
                          // тут ставим время через которое скрипт обновится
   setInterval( function(){ setupEvent( 'raspisanie', data ); }, (1000*60) );
 
})();
  
</script>


Здесь содержание файла .js

Дни недели идут в следующем порядке:
0 - воскресенье
1 - понедельник
2 - вторник
3 - среда
4 - четверг
5 - пятница
6 - суббота

в таблице первая цифра время "от", вторая "до", далее цвет и последнее, текст который будет отображаться.

Кликните здесь для просмотра всего текста

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
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
var data = {
0 : [
[8, 9, "red", 'UB0ABG, RU0AMM'],
[9, 10, "red", 'Гараж'],
[10, 11, "red", 'Гайвер, Гараж'],
[11, 12, "red", 'Гайвер, Гараж'],
[12, 13, "red", 'Гайвер, КОТ 94'],
[13, 14, "red", 'RV0ALG, UB0ACI'],
[14, 15, "red", 'UB0ACI, R0ACW'],
[15, 16, "red", 'UB0ACI, R0ACW'],
[16, 17, "red", 'UB0ACI, R0ACW'],
[17, 18, "red", 'UB0ACI, RU0AB'],
[18, 19, "red", 'UB0ACI, RU0AB'],
[19, 20, "red", 'UB0AFF, UB0ACI'],
[20, 21, "red", 'Егорыч, UB0ACI, UB0AFF'],
[21, 22, "red", 'RU0AMM, UB0ACI, UB0ADQ, Егорыч'],
[22, 23, "red", 'UB0ABG, RU0AMM, UB0ACI'],
[23, 8, "red", 'RE0RAS']
],
1 : [
[8, 9, "red", 'R0ADW, UB0ABG, RU0AMM, R0AEC, R0ADH, R0ACK'],
[9, 10, "red", 'R0ADW, R0ACK, UB0ABA'],
[10, 11, "red", 'R0ADV, Гайвер, UB0ABA'],
[11, 12, "red", 'RU0APN, R0ADV, Гайвер'],
[12, 13, "red", 'RU0APN, R0ADV, Гайвер, КОТ 94'],
[13, 14, "red", 'RU0APN, R0ADV, R0ACY'],
[14, 15, "red", 'RU0APN, R0ABT, R0ADV, Кореец'],
[15, 16, "red", 'RU0APN, R0ADV, R0ACY'],
[16, 17, "red", 'R0ACK, R0ADV'],
[17, 18, "red", 'UB0AAZ, UB0AFF, R0ADV'],
[18, 19, "red", 'UB0AAZ, R0AAZ, R0ACY'],
[19, 20, "red", 'UB0AAZ, R0AAZ'],
[20, 21, "red", 'UB0AAZ, R0ABD, Егорыч'],
[21, 22, "red", 'UB0AAZ, RU0AMM, RV0ALG, R0ADH, R0ACK, Егорыч'],
[22, 23, "red", 'UB0AAZ, UB0ABG, RU0AMM, R0AEC'],
[23, 8, "red", 'RE0RAS']
],
2 : [
[8, 9, "red", 'R0ADW, UB0ABG, RU0AMM, R0ADH, R0ACK'],
[9, 10, "red", 'R0ADW, R0ACK, 28'],
[10, 11, "red", 'R0ADV, Гайвер, 28'],
[11, 12, "red", 'RU0APN, R0ADV, Гайвер, 28'],
[12, 13, "red", 'RU0APN, R0ADV, Гайвер, КОТ 94, 28'],
[13, 14, "red", 'RU0APN, R0ADV, 28'],
[14, 15, "red", 'RU0APN, R0ABT, R0ADV, 28, Кореец'],
[15, 16, "red", 'RU0APN, R0ADV, 28'],
[16, 17, "red", 'R0ACK, R0ADV, 28'],
[17, 18, "red", 'UB0AAZ, UB0AFF, UB0ADQ, R0ADV, 28'],
[18, 19, "red", 'UB0AAZ, R0AAZ'],
[19, 20, "red", 'UB0AAZ, R0AAZ'],
[20, 21, "red", 'UB0AAZ, R0ABD, Егорыч'],
[21, 22, "red", 'UB0AAZ, RU0AMM, RV0ALG, R0ADH, R0ACK, Егорыч'],
[22, 23, "red", 'UB0AAZ, UB0ABG, RU0AMM'],
[23, 8, "red", 'RE0RAS']
],
3 : [
[8, 9, "red", 'R0ADW, UB0ABG, RU0AMM, R0AEC, R0ADH, R0ACK'],
[9, 10, "red", 'R0ADW, R0ACK, UB0ABA'],
[10, 11, "red", 'R0ADV, Гайвер, UB0ABA'],
[11, 12, "red", 'RU0APN, R0ADV, Гайвер'],
[12, 13, "red", 'RU0APN, R0ADV, Гайвер, КОТ 94'],
[13, 14, "red", 'RU0APN, R0ADV, R0ACY'],
[14, 15, "red", 'RU0APN, R0ABT, R0ADV, Кореец'],
[15, 16, "red", 'RU0APN, R0ADV, R0ACY'],
[16, 17, "red", 'R0ACK, R0ADV'],
[17, 18, "red", 'UB0AAZ, UB0AFF, UB0ADQ, R0ADV'],
[18, 19, "red", 'UB0AAZ, R0AAZ, R0ACY'],
[19, 20, "red", 'UB0AAZ, R0AAZ'],
[20, 21, "red", 'UB0AAZ, R0ABD, Егорыч'],
[21, 22, "red", 'UB0AAZ, RU0AMM, RV0ALG, R0ADH, R0ACK, Егорыч'],
[22, 23, "red", 'UB0AAZ, UB0ABG, RU0AMM, R0AEC'],
[23, 8, "red", 'RE0RAS']
],
4 : [
[8, 9, "red", 'R0ADW, UB0ABG, RU0AMM, R0ACK'],
[9, 10, "red", 'R0ADW, R0ACK, 28'],
[10, 11, "red", 'R0ADV, Гайвер, 28'],
[11, 12, "red", 'RU0APN, R0ADV, Гайвер'],
[12, 13, "red", 'RU0APN, R0ADV, Гайвер, 28'],
[13, 14, "red", 'RU0APN, R0ADV, 28'],
[14, 15, "red", 'RU0APN, R0ABT, R0ADV, Кореец'],
[15, 16, "red", 'RU0APN, R0ADV, 28'],
[16, 17, "red", 'R0ACK, R0ADV, 28'],
[17, 18, "red", 'UB0AAZ, UB0AFF, UB0ADQ, 28'],
[18, 19, "red", 'UB0AAZ, R0AAZ'],
[19, 20, "red", 'UB0AAZ, R0AAZ'],
[20, 21, "red", 'UB0AAZ, R0ABD, Егорыч'],
[21, 22, "red", 'UB0AAZ, RU0AMM, RV0ALG, R0ACK, Егорыч'],
[22, 23, "red", 'UB0AAZ, UB0ABG, RU0AMM'],
[23, 8, "red", 'RE0RAS']
],
5 : [
[8, 9, "red", 'R0ADW, UB0ABG, RU0AMM, R0AEC, R0ACK'],
[9, 10, "red", 'R0ADW, R0ACK, UB0ABA'],
[10, 11, "red", 'R0ADV, Гайвер, UB0ABA'],
[11, 12, "red", 'RU0APN, R0ADV, Гайвер'],
[12, 13, "red", 'RU0APN, R0ADV, Гайвер, КОТ 94'],
[13, 14, "red", 'RU0APN, R0ADV, R0ACY'],
[14, 15, "red", 'RU0APN, R0ABT, R0ADV, Кореец'],
[15, 16, "red", 'RU0APN, R0ADV, R0ACY'],
[16, 17, "red", 'R0ACK, R0ADV'],
[17, 18, "red", 'UB0AAZ, UB0AFF, R0ADV'],
[18, 19, "red", 'UB0AAZ, R0AAZ, R0ACY'],
[19, 20, "red", 'UB0AAZ, R0AAZ'],
[20, 21, "red", 'UB0AAZ, Егорыч'],
[21, 22, "red", 'UB0AAZ, RU0AMM, RV0ALG, R0ACK, Егорыч'],
[22, 23, "red", 'UB0AAZ, UB0ABG, RU0AMM, R0AEC'],
[23, 8, "red", 'RE0RAS']
],
6 : [
[8, 9, "red", 'UB0ABG, RU0AMM'],
[9, 10, "red", 'Гараж'],
[10, 11, "red", 'Гайвер, Гараж'],
[11, 12, "red", 'Гайвер, Гараж'],
[12, 13, "red", 'Гайвер, КОТ 94'],
[13, 14, "red", 'RV0ALG, UB0ACI'],
[14, 15, "red", 'UB0ACI, R0ACW'],
[15, 16, "red", 'UB0ACI, R0ACW'],
[16, 17, "red", 'UB0ACI, R0ACW'],
[17, 18, "red", 'UB0ACI, R0ACW'],
[18, 19, "red", 'UB0ACI, R0ACW'],
[19, 20, "red", 'UB0AFF, UB0ACI'],
[20, 21, "red", 'Егорыч, UB0ACI, UB0AFF'],
[21, 22, "red", 'RU0AMM, Егорыч'],
[22, 23, "red", 'UB0ABG, RU0AMM'],
[23, 8, "red", 'RE0RAS']
]
};
0
0 / 0 / 0
Регистрация: 18.10.2014
Сообщений: 23
21.10.2014, 17:52  [ТС]
0
0 / 0 / 0
Регистрация: 21.04.2017
Сообщений: 4
21.04.2017, 14:38
А как в расписание добавить минуты?
0
Develo0per
 Аватар для and_y87
424 / 368 / 75
Регистрация: 27.02.2012
Сообщений: 1,379
Записей в блоге: 98
21.04.2017, 15:24
Если проверять ещё и минуты я во первых в этом случае привёл бы "библиотеку данных" к такому формату:
JavaScript
1
2
3
4
5
6
7
8
var data = {
  // 0 - порядковый день недели "понедельник"
  0 : [
    [ [8,30], [9,10], ['text text text text ',"red"]],
    [ [9,10], [9,45], ['test test test test ',"blue"]],
  ],
  //1 : ...
]
удобнее визуально понимать...

по поводу определения необходимой записи... всё относительно просто...
определяем текущий день, час, минуту и перебором со сравнением ищем необходимую запись...
где значения будут соответствовать текущему времени... часы и минуты из первого массива, больше или равны текущим и меньше чем предельные, из второго массива...

Добавлено через 36 секунд
P.S. при такой структуре можно задать стандартные значения для минут и цвета.
1
0 / 0 / 0
Регистрация: 21.04.2017
Сообщений: 4
21.04.2017, 15:36
and_y87, Вставил, пишет undifined... Что-то еще может надо поменять? я в Javascript вообще не шарю.. Нужно просто на сайт сделать вывод расписания по дням недели, времени и минутам... Заранее спасибо
0
Develo0per
 Аватар для and_y87
424 / 368 / 75
Регистрация: 27.02.2012
Сообщений: 1,379
Записей в блоге: 98
21.04.2017, 16:10
Цитата Сообщение от Mvolk Посмотреть сообщение
and_y87, Вставил, пишет undifined... Что-то еще может надо поменять? я в Javascript вообще не шарю.. Нужно просто на сайт сделать вывод расписания по дням недели, времени и минутам... Заранее спасибо
Моё предыдущее сообщение имеет уже совсем другую логику JS нежели замысел автора...
сейчас не могу, позже выложу пример кода, который с этим справится... если до меня никто этого не сделает...
0
0 / 0 / 0
Регистрация: 21.04.2017
Сообщений: 4
21.04.2017, 16:36
and_y87, Спасибо!! Буду ждать!
0
Develo0per
 Аватар для and_y87
424 / 368 / 75
Регистрация: 27.02.2012
Сообщений: 1,379
Записей в блоге: 98
24.04.2017, 13:12
Цитата Сообщение от Mvolk Посмотреть сообщение
and_y87, Спасибо!! Буду ждать!
Представляю в виде небольшого плагина, на чистом JS(без JQ).

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
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
var
 
data    = {
    0 : [
        [ [13,00], [13,30], ['text text text text 5 ']],
        [ [13,30], [14,00], ['text text text text 6 ']],
        [ [14,00], [14,30], ['test test test test 7 ',"blue"]],
        [ [14,30], [15,00], ['test test test test 8 ',"blue"]],
        [ [15,00], [18,00], ['test test test test 9']]
    ]
    //1 : ...
},
 
core    = {
 
    id      : '',
 
    item    : null,
 
    timer   : null,
 
    data    : {},
 
    options : {
        color   : "red",
        time    : 60000,
        text    : 'default text'
    },
 
 
    initRow    : function()
    {
        var text, data,
            d   = new Date(),
            h   = d.getHours(),
            m   = d.getMinutes();
 
        d   = d.getDay();
 
        if( this.data[d] == undefined ) return [['Day(' +d+ ') Not Found']];
 
        data = this.data[d];
        text = [core.options.text];
 
        var len = data.length;
 
        for( var i=0; i < len; i++)
        {
            if ( data[i][0][0] <= h && h <= data[i][1][0] && ( data[i][0][1] <= m && m < data[i][1][1] ) )
            {
                text = data[i][2];
            }
        }
        core.setupRow(text[0], (text[1]) ? text[1] : core.options.color );
    },
 
    setupRow    : function(text, color)
    {
        this.item.innerHTML     = text;
        this.item.style.color   = color;
    },
 
    init        : function( data, id,  opt )
    {
        this.data       = data;
 
        if (opt != undefined )
        {
            if ( opt.color ) this.options.color = opt.color;
            if ( opt.time ) this.options.time = opt.time;
            if ( opt.text ) this.options.text = opt.text;
        }
        this.id         = id;
        this.item       = document.getElementById( this.id );
        this.timer      = setInterval(core.initRow, this.options.time);
 
        this.initRow();
    }
};
 
(function(){
 
    core.init(data, 'id_text', {
        color   : "green"
    });
 
})();
Будут вопросы пиши...
1
0 / 0 / 0
Регистрация: 21.04.2017
Сообщений: 4
05.05.2017, 15:48
and_y87, вставил этот код в <script type="text/javascript"> </script> и что-то не работает.. Сорри за тупость, в javascript вообще не разбираюсь. 0 догадался что это воскресенье и поменял на 5 пятницу чтобы проверить работоспособность.
0
34 / 1 / 0
Регистрация: 01.06.2013
Сообщений: 50
10.10.2018, 18:21
Я конечно понимаю что прошло много времени, но все же, может кто подскажет как вывести например сегодня понедельник, выводится R0ADW, R0ACK, UB0ABA, а как еще вывести воскресенье и вторник, но отдельными строчками.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
10.10.2018, 18:21
Помогаю со студенческими работами здесь

Вывод разных значений в зависимости от дня недели
Пишу консольное приложение, нужно что бы в зависимости от дня недели при запуске выдавало разные значения, например: if(дата =...

Автоматизация заполнения таблицы в зависимости от дня недели
Доброго дня! Возник такой вопрос - каким способом проще всего подцеплять данные в таблицы из другой в зависимости какой день недели. К...

Написать программу, которая запрашивает у пользователя номер дня недели, затем выводит название дня недели
Написать программу, которая запрашивает у пользователя номер дня недели, затем выводит название дня недели или сообщение об ошибке, если...

Найти номер дня недели К-го дня года, если в этом году 1 января было днем недели с номером N
Дни недели пронумерованы следующим образом: 0 - воскресенье, 1 - понедельник, 2 - вторник, ..., 6 - суббота. Даны целые числа K в...

Написать программу, которая по номеру дня недели (целому числу от 1 до 7) выдает в качестве результата название дня недели
!!!!!


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

Или воспользуйтесь поиском по форуму:
50
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
SDL3 для Android: Загрузка PNG с альфа-каналом с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru