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

При смене даты в календарике менять картинку фона. При этом чтобы дата внизу и "созвездие" приходились на текущую дату.

16.11.2018, 14:35. Показов 972. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте!
Прошу помощи в следующей ситуации.
Опыта особого в JavaScript не имею по этой причине за основу взял несколько хорошо известных кодов, подработал их под себя.
Но вот в итог, вывести не получается, по отдельности все работает.
Необходимо чтобы в календарике при смене (вперед назад) в нем менялась картинка фона месяца. При этом дата внизу и "созвездие" приходились на текущую дату.
С уважением,Аватар-С!
PHP/HTML
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
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
<!DOCTYPE html> 
<html>
<head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    <title>Календарик</title>
 
    <style>
        *{
            margin:0;
            padding:0;
            box-sizing:border-box;
        }
        html {
            font-family: Verdana, Impact, Trebuchet MS;
            height:100%;
            font-size:100%;
        }
            selector {
                font-size:1,875em;
                font-size:2.5vw;
            }
 
        @charset "UTF-8"; body {
            font-style:normal;
            color:blue;
        }
 
        
        
        #content{
            width: calc(100% - 470px);
            height:900px;
            padding:5px;
            float:left;
            background:#fff/* Violet */;
        }
        
        #right{
            display:block;
            z-index:2;
            width: 250px;
            height: 900px;
            float: left;
        }       
        
        #right_a{
            position:fixed;
            display:block;
            width:250px;
            height:400px;
            padding-top:10px;
            text-align:center;
        }       
        
        #right_b{
            display:block;
            width:230px;
            height:345px;
            background-image:url(file:///c:/сайт/img/calendar/default.jpg);
            border: 1px solid blue;
            margin:0 auto;
            border-radius:5px;
        }
 
 
 
        #calendar {
            padding-top:10px;
            margin:0 auto;
            width:200px; /*182*/
            line-height:1.2em;
            font-size:14px; /* 15px; */
        }
        
        #calendar b {
            color:#fff;
            font-weight:400;
            font-size:x-large;
            text-align:center;
        }
 
        #calendar span { color:red; }
 
        #calendar thead tr:last-child {
            font-size:small;
            font-weight:600;
            color:blue; /* название дней недели */
        }
        
        #calendar thead tr:nth-child(1) th:nth-child(2) {
            color:#fff; /* название мес¤ца */
            padding:15px 0;
            font-size: 11pt; /*25*/
            /*font-family:Mistral;*/
        }
        
        #calendar th {
            border:1px solid blue; /* белая полоса между ... */
            width:50px; /*26*/
            background:blue;
            border-collapse:collapse;
        }
 
        #calendar thead tr:nth-child(1) th:nth-child(1):hover,
        #calendar thead tr:nth-child(1) th:nth-child(3):hover {
            cursor: pointer;
        }
        
        #calendar tbody td {
            margin: auto; /* таблица по центру */
            padding:0 5px; /* между столбцами */
            color:blue; /*  даты календары - рабочие дни */
            height:27px; /* между строк */
        }
        
        #calendar tbody td:nth-child(n+6), #calendar .holiday {
            color:red; / *rgb(231, 140, 92); даты календаря - выходные дни */
        }
        
        #calendar tbody td.today {
            background:blue; /* дата сегодня */
            border-radius:5px;
            color:#fff;
        }
    </style>
</head>
<body>
        <!-- КОНТЕНТ -->
        <div id="content">
        <p style="font-size:xx-small;">xx-small</p>
        <p style="font-size:x-small;">x-small</p>
        <p style="font-size:small;">small</p>
        
        <p style="font-size:medium;">medium</p>
        <p style="font-size:large;">large</p>
        <p style="font-size:x-large;">x-large</p>
        <p style="font-size:xx-large;">xx-large</p>
        
        </div>
        
        <!-- ПРАВАЯ КОЛОНКА -->
        <div id="right">
        <div id="right_a">
        <div id="right_b">
    
        <script>
            function init() {
                var Data = new Date();
                var vDay = Data.getDate();
                var vMonth = Data.getMonth();
                var vYear = Data.getFullYear();
                var src;
                var path = "url('file:///c:/сайт/img/calendar/"; // путь
                
                var vMonth = parseInt(window.prompt('Введите месяц в формате 1 и.д.', '1')); // для теста
                
                if (vMonth == 1) {src = path + "01.jpg')";}
                    else if (vMonth == 2 ){src = path + "02.jpg')";}
                    else if (vMonth == 3 ){src = path + "03.jpg')";}
                    else if (vMonth == 4 ){src = path + "04.jpg')";}
                    else if (vMonth == 5 ){src = path + "05.jpg')";}
                    else if (vMonth == 6 ){src = path + "06.jpg')";}
                    else if (vMonth == 7 ){src = path + "07.jpg')";}
                    else if (vMonth == 8 ){src = path + "08.jpg')";}
                    else if (vMonth == 9 ){src = path + "09.jpg')";}
                    else if (vMonth == 10){src = path + "10.jpg')";}
                    else if (vMonth == 11){src = path + "11.jpg')";}
                    else if (vMonth == 12){src = path + "12.jpg')";}
 
                var div = document.getElementById('right_b');
                div.style.backgroundImage = src;
            }
            window.onload = init;
            
            
            switch (vMonth) {
                case 1: if (vDay <= 19) vZnak = 'Козерога',     vSimvol = '♑'; else vZnak = 'Водолея', vSimvol = '♒';    break;
                case 2: if (vDay <= 18) vZnak = 'Водолея',       vSimvol = '♒'; else vZnak = 'Рыбы',       vSimvol = '♓';    break;
                case 3: if (vDay <= 20) vZnak = 'Рыбы',         vSimvol = '♓'; else vZnak = 'Овена',     vSimvol = '♈';    break;
                case 4: if (vDay <= 19) vZnak = 'Овена',       vSimvol = '♈'; else vZnak = 'Телеца',       vSimvol = '♉';    break;
                case 5: if (vDay <= 20) vZnak = 'Телеца',     vSimvol = '♉'; else vZnak = 'Близнецов', vSimvol = '♊';    break;
                case 6: if (vDay <= 21) vZnak = 'Близнецов',   vSimvol = '♊'; else vZnak = 'Рака',       vSimvol = '♋';    break;
                case 7: if (vDay <= 22) vZnak = 'Рака',         vSimvol = '♋'; else vZnak = 'Лева',       vSimvol = '♌';    break;
                case 8: if (vDay <= 22) vZnak = 'Лева',         vSimvol = '♌'; else vZnak = 'Девы',       vSimvol = '♍';    break;
                case 9: if (vDay <= 22) vZnak = 'Девы',         vSimvol = '♍'; else vZnak = 'Весов',     vSimvol = '♎';    break;
                case 10:if (vDay <= 22) vZnak = 'Весов',       vSimvol = '♎'; else vZnak = 'Скорпион',   vSimvol = '♏';    break;
                case 11:if (vDay <= 22) vZnak = 'Скорпиона',   vSimvol = '♏'; else vZnak = 'Стрелеца',   vSimvol = '♐';    break;
                case 12:if (vDay <= 21) vZnak = 'Стрелеца',     vSimvol = '♐'; else vZnak = 'Козерога',   vSimvol = '♑';    break;
            }
            var z = vZnak; //var s = vSimvol;
        </script>
        
        
        
        <table id="calendar" cellspacing="0" style="position: relative">
        <thead title="Пожалуйста! Определитесь с датой заказа.">
            <tr><th style="border-radius: 5px 0 0 5px;"><b>&laquo;<th colspan="5" ><th style="border-radius: 0 5px 5px 0;"><b>&raquo;
            <tr><td>пн<td>вт<td>ср<td>чт<td>пт<td><span>сб<td><span>вс
        <tbody></tbody>
        </table>
 
        <br>
        <p style="text-align:left; padding-left:35px; font-size:small;">сегодня: <script type="text/javascript">document.write(vDay+'.'+vMonth+'.'+vYear)</script></p>
        <p style="text-align:left; padding-left:20px; font-size:small;">созвездие: <script type="text/javascript">document.write(z)</script></p>
        
        <script>
            function calendar(id, year, month) {
            var Dlast = new Date(year,month+1,0).getDate(),
                D = new Date(year,month,Dlast),
                DNlast = new Date(D.getFullYear(),D.getMonth(),Dlast).getDay(),
                DNfirst = new Date(D.getFullYear(),D.getMonth(),1).getDay(),
                calendar = '<tr>',
                vMonth=["Январь","Февраль","Март","Апрель","Май","Июнь","Июль","Август","Сентябрь","Октябрь","Ноябрь","Декабрь"];
            if (DNfirst != 0) {
              for(var  i = 1; i < DNfirst; i++) calendar += '<td>';
            }else{
              for(var  i = 0; i < 6; i++) calendar += '<td>';
            }
            for(var  i = 1; i <= Dlast; i++) {
              if (i == new Date().getDate() && D.getFullYear() == new Date().getFullYear() && D.getMonth() == new Date().getMonth()) {
                calendar += '<td class="today">' + i;
              }else{
                if (
                    (i == 1 && D.getMonth() == 0 && ((D.getFullYear() > 1897 && D.getFullYear() < 1930) || D.getFullYear() > 1947)) ||
                    (i == 2 && D.getMonth() == 0 && D.getFullYear() > 1992) ||
                    ((i == 3 || i == 4 || i == 5 || i == 6 || i == 8) && D.getMonth() == 0 && D.getFullYear() > 2004) ||
                    (i == 7 && D.getMonth() == 0 && D.getFullYear() > 1990) ||
                    (i == 23 && D.getMonth() == 1 && D.getFullYear() > 2001) ||
                    (i == 8 && D.getMonth() == 2 && D.getFullYear() > 1965) ||
                    (i == 1 && D.getMonth() == 4 && D.getFullYear() > 1917) ||
                    (i == 9 && D.getMonth() == 4 && D.getFullYear() > 1964) ||
                    (i == 12 && D.getMonth() == 5 && D.getFullYear() > 1990) ||
                    (i == 7 && D.getMonth() == 10 && (D.getFullYear() > 1926 && D.getFullYear() < 2005)) ||
                    (i == 8 && D.getMonth() == 10 && (D.getFullYear() > 1926 && D.getFullYear() < 1992)) ||
                    (i == 4 && D.getMonth() == 10 && D.getFullYear() > 2004)
                   ) {
                  calendar += '<td class="holiday">' + i;
                }else{
                  calendar += '<td>' + i;
                }
              }
              if (new Date(D.getFullYear(),D.getMonth(),i).getDay() == 0) {
                calendar += '<tr>';
              }
            }
            
            for(var  i = DNlast; i < 7; i++) calendar += '<td> ';
            document.querySelector('#'+id+' tbody').innerHTML = calendar;
                        document.querySelector('#'+id+' thead th:nth-child(2)').innerHTML = vMonth[D.getMonth()] + ' ' + D.getFullYear();
                        document.querySelector('#'+id+' thead th:nth-child(2)').dataset.vMonth = D.getMonth();
                        document.querySelector('#'+id+' thead th:nth-child(2)').dataset.year = D.getFullYear();
                        
            if (document.querySelectorAll('#'+id+' tbody tr').length < 6) {  // чтобы при перелистывании месяцев не "подпрыгивала" вся страница, добавляется ряд пустых клеток. Итог: всегда 6 строк для цифр
                document.querySelector('#'+id+' tbody').innerHTML += '<tr><td> <td> <td> <td> <td> <td> <td> ' ;
            }
            }
            calendar("calendar", new Date().getFullYear(), new Date().getMonth());
            // переключатель минус месяц
                        document.querySelector('#calendar thead tr:nth-child(1) th:nth-child(1)').onclick = function() {
                            calendar("calendar", document.querySelector('#calendar thead th:nth-child(2)').dataset.year, parseFloat(document.querySelector('#calendar thead th:nth-child(2)').dataset.vMonth)-1);
                        }
            // переключатель плюс месяц
                        document.querySelector('#calendar thead tr:nth-child(1) th:nth-child(3)').onclick = function() {
                            calendar("calendar", document.querySelector('#calendar thead th:nth-child(2)').dataset.year, parseFloat(document.querySelector('#calendar thead th:nth-child(2)').dataset.vMonth)+1);
                        }
 
        </script>
 
        </div>
        </div>
    </div>
 
</body>
</html>
Вложения
Тип файла: rar calendar.rar (168.3 Кб, 1 просмотров)
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
16.11.2018, 14:35
Ответы с готовыми решениями:

Как сделать так чтобы при смене даты менялись и данные
Есть база данных. Там данные. В одной ячейке написана дата. Как сделать так чтобы при смене даты менялись и данные.

Дата: Получить текущую дату и дату +7 дней...
В общем проблема такая... Через кнопку у меня должно появляться текущее дата и рядом дата +7 дней. т.е. вводит &quot;10.02.17&quot; и...

Вывести дату в поле со списком только один раз при выборке (чтобы даты не повторялись)
Есть поле со списком, данное поле заполняется при помощи запроса который выгружает даты всех записей в таблице. Если развернуть список...

1
 Аватар для Аватар-С
1 / 1 / 0
Регистрация: 03.02.2017
Сообщений: 102
20.11.2018, 11:00  [ТС]
Здравствуйте!
Немного продвинулся, в решении заданного вопроса.
Осталось научиться менять фон календарика при смене месяца с помощью перелистывания. Понятно что необходимо редактировать функцию начиная со строки 259.
Но ни как не соображу с чего начать.
Если не сложно дайте подсказку.

С уважением, Аватар-С!


PHP/HTML
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
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
<!DOCTYPE html> 
<html>
<head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    <title>Календарик</title>
 
    <style>
        *{
            margin:0;
            padding:0;
            box-sizing:border-box;
        }
        html {
            font-family: Verdana, Impact, Trebuchet MS;
            height:100%;
            font-size:100%;
        }
            selector {
                font-size:1,875em;
                font-size:2.5vw;
            }
 
        @charset "UTF-8"; body {
            font-style:normal;
            color:blue;
        }
 
        
        
        #content {
            width: calc(100% - 470px);
            height:900px;
            padding:5px;
            float:left;
            background:#fff/* Violet */;
        }
        
        #right {
            display:block;
            z-index:2;
            width: 250px;
            height: 900px;
            float: left;
        }       
        
        #right_a {
            position:fixed;
            display:block;
            width:250px;
            height:400px;
            padding-top:10px;
            text-align:center;
        }       
        
        #right_b {
            display:block;
            width:230px;
            height:345px;
            background-image:url(file:///c:/сайт/img/calendar/default.jpg);
            border: 1px solid blue;
            margin:0 auto;
            border-radius:5px;
        }
 
 
 
        #calendar {
            padding-top:10px;
            margin:0 auto;
            width:200px; /*182*/
            line-height:1.2em;
            font-size:14px; /* 15px; */
        }
        
        #calendar b {
            color:#fff;
            font-weight:400;
            font-size:x-large;
            text-align:center;
        }
 
        #calendar span { color:red; }
 
        #calendar thead tr:last-child {
            font-size:small;
            font-weight:600;
            color:blue; /* название дней недели */
        }
        
        #calendar thead tr:nth-child(1) th:nth-child(2) {
            color:#fff; /* название мес¤ца */
            padding:15px 0;
            font-size: 11pt; /*25*/
            /*font-family:Mistral;*/
        }
        
        #calendar th {
            border:1px solid blue; /* белая полоса между ... */
            width:50px; /*26*/
            background:blue;
            border-collapse:collapse;
        }
 
        #calendar thead tr:nth-child(1) th:nth-child(1):hover,
        #calendar thead tr:nth-child(1) th:nth-child(3):hover {
            cursor: pointer;
        }
        
        #calendar tbody td {
            margin: auto; /* таблица по центру */
            padding:0 5px; /* между столбцами */
            color:blue; /*  даты календары - рабочие дни */
            height:27px; /* между строк */
        }
        
        #calendar tbody td:nth-child(n+6), #calendar .holiday {
            color:red; / *rgb(231, 140, 92); даты календаря - выходные дни */
        }
        
        #calendar tbody td.today {
            background:blue; /* дата сегодня */
            border-radius:5px;
            color:#fff;
        }
    </style>
    <script>
        var mNames=["января","февраля","марта","апреля","мая","июня","июля","августа","сентября","октября","ноября","декабря"];
        var nD = new Date(); var nDate = nD.getDate(); var nMonth = nD.getMonth(); var cYear = nD.getFullYear();
        switch (nMonth) {
            case 1: if (nD <= 19) vZnak = 'Козерога';   else vZnak = 'Водолея';      break;
            case 2: if (nD <= 18) vZnak = 'Водолея'; else vZnak = 'Рыбы';        break;
            case 3: if (nD <= 20) vZnak = 'Рыбы';       else vZnak = 'Овена';      break;
            case 4: if (nD <= 19) vZnak = 'Овена';     else vZnak = 'Телеца';        break;
            case 5: if (nD <= 20) vZnak = 'Телеца';       else vZnak = 'Близнецов';  break;
            case 6: if (nD <= 21) vZnak = 'Близнецов'; else vZnak = 'Рака';        break;
            case 7: if (nD <= 22) vZnak = 'Рака';       else vZnak = 'Лева';        break;
            case 8: if (nD <= 22) vZnak = 'Лева';       else vZnak = 'Девы';        break;
            case 9: if (nD <= 22) vZnak = 'Девы';       else vZnak = 'Весов';      break;
            case 10:if (nD <= 22) vZnak = 'Весов';     else vZnak = 'Скорпиона';  break;
            case 11:if (nD <= 22) vZnak = 'Скорпиона'; else vZnak = 'Стрелеца';    break;
            case 12:if (nD <= 21) vZnak = 'Стрелеца';   else vZnak = 'Козерога';    break;
        }
        var z = vZnak; 
        nDay = (nDate + " " + mNames[nMonth]+ " " + cYear);
        //window.alert(nDay)
    </script>
</head>
<body>
        <!-- КОНТЕНТ -->
        <div id="content">
        <p style="font-size:xx-small;">xx-small</p>
        <p style="font-size:x-small;">x-small</p>
        <p style="font-size:small;">small</p>
        
        <p style="font-size:medium;">medium</p>
        <p style="font-size:large;">large</p>
        <p style="font-size:x-large;">x-large</p>
        <p style="font-size:xx-large;">xx-large</p>
        </div>
        
        <!-- ПРАВАЯ КОЛОНКА -->
        <div id="right">
        <div id="right_a">
        <div id="right_b">
            <table id="calendar" cellspacing="0" style="position: relative">
            <thead title="Пожалуйста! Определитесь с датой заказа.">
                <tr><th style="border-radius: 5px 0 0 5px;"><b>&laquo;<th colspan="5" ><th style="border-radius: 0 5px 5px 0;"><b>&raquo;
                <tr><td>пн<td>вт<td>ср<td>чт<td>пт<td><span>сб<td><span>вс
            <tbody></tbody>
            </table>
            <br>
            <p style="text-align:left; padding-left:35px; font-size:small;">сегодня: <script type="text/javascript">document.write(nDay)</script></p>
            <p style="text-align:left; padding-left:20px; font-size:small;">созвездие: <script type="text/javascript">document.write(z)</script></p>
            
            <!-- <input type="button" value="Reload Page" onClick="window.location.reload()"> -->
            <input type="button" value="обновить" onClick="history.go(0)" style="padding:5px 10px; margin-top:10px; border:1px solid blue; color:#fff; background:blue; border-radius:5px;">
            <!-- <input type="button" value="обновить" onClick="window.location.href=window.location.href" style="padding:5px; margin-top:5px; border:1px solid blue; color:blue; border-radius:5px;"> -->
        <script>
    function Refresh() {
        window.parent.location = window.parent.location.href;
    }
</script>
        <script>
            function init() {
                var Data = new Date(); var vDay = Data.getDate(); var vMonth = Data.getMonth(); var vYear = Data.getFullYear();
                var src; var path = "url('file:///c:/сайт/img/calendar/"; // путь
                //var vMonth = parseInt(window.prompt('Введите месяц в формате 1 и.д.', '1')); // для теста
                
                if (vMonth == 1) {src = path + "01.jpg')";}
                    else if (vMonth == 2 ){src = path + "02.jpg')";}
                    else if (vMonth == 3 ){src = path + "03.jpg')";}
                    else if (vMonth == 4 ){src = path + "04.jpg')";}
                    else if (vMonth == 5 ){src = path + "05.jpg')";}
                    else if (vMonth == 6 ){src = path + "06.jpg')";}
                    else if (vMonth == 7 ){src = path + "07.jpg')";}
                    else if (vMonth == 8 ){src = path + "08.jpg')";}
                    else if (vMonth == 9 ){src = path + "09.jpg')";}
                    else if (vMonth == 10){src = path + "10.jpg')";}
                    else if (vMonth == 11){src = path + "11.jpg')";}
                    else if (vMonth == 12){src = path + "12.jpg')";}
                var div = document.getElementById('right_b');
                div.style.backgroundImage = src;
            }
            window.onload = init;
 
 
 
 
            function calendar(id, year, month) {
            var Dlast = new Date(year,month+1,0).getDate(),
                D = new Date(year,month,Dlast),
                DNlast = new Date(D.getFullYear(),D.getMonth(),Dlast).getDay(),
                DNfirst = new Date(D.getFullYear(),D.getMonth(),1).getDay(),
                calendar = '<tr>',
                vMonth=["Январь","Февраль","Март","Апрель","Май","Июнь","Июль","Август","Сентябрь","Октябрь","Ноябрь","Декабрь"];
            if (DNfirst != 0) {
              for(var  i = 1; i < DNfirst; i++) calendar += '<td>';
            }else{
              for(var  i = 0; i < 6; i++) calendar += '<td>';
            }
            for(var  i = 1; i <= Dlast; i++) {
              if (i == new Date().getDate() && D.getFullYear() == new Date().getFullYear() && D.getMonth() == new Date().getMonth()) {
                calendar += '<td class="today">' + i;
              }else{
                if (
                    (i == 1 && D.getMonth() == 0 && ((D.getFullYear() > 1897 && D.getFullYear() < 1930) || D.getFullYear() > 1947)) ||
                    (i == 2 && D.getMonth() == 0 && D.getFullYear() > 1992) ||
                    ((i == 3 || i == 4 || i == 5 || i == 6 || i == 8) && D.getMonth() == 0 && D.getFullYear() > 2004) ||
                    (i == 7 && D.getMonth() == 0 && D.getFullYear() > 1990) ||
                    (i == 23 && D.getMonth() == 1 && D.getFullYear() > 2001) ||
                    (i == 8 && D.getMonth() == 2 && D.getFullYear() > 1965) ||
                    (i == 1 && D.getMonth() == 4 && D.getFullYear() > 1917) ||
                    (i == 9 && D.getMonth() == 4 && D.getFullYear() > 1964) ||
                    (i == 12 && D.getMonth() == 5 && D.getFullYear() > 1990) ||
                    (i == 7 && D.getMonth() == 10 && (D.getFullYear() > 1926 && D.getFullYear() < 2005)) ||
                    (i == 8 && D.getMonth() == 10 && (D.getFullYear() > 1926 && D.getFullYear() < 1992)) ||
                    (i == 4 && D.getMonth() == 10 && D.getFullYear() > 2004)
                   ) {
                  calendar += '<td class="holiday">' + i;
                }else{
                  calendar += '<td>' + i;
                }
              }
              if (new Date(D.getFullYear(),D.getMonth(),i).getDay() == 0) {
                calendar += '<tr>';
              }
            }
            
            for(var  i = DNlast; i < 7; i++) calendar += '<td> ';
            document.querySelector('#'+id+' tbody').innerHTML = calendar;
                        document.querySelector('#'+id+' thead th:nth-child(2)').innerHTML = vMonth[D.getMonth()] + ' ' + D.getFullYear();
                        document.querySelector('#'+id+' thead th:nth-child(2)').dataset.vMonth = D.getMonth();
                        document.querySelector('#'+id+' thead th:nth-child(2)').dataset.year = D.getFullYear();
                        
            if (document.querySelectorAll('#'+id+' tbody tr').length < 6) {  // чтобы при перелистывании месяцев не "подпрыгивала" вся страница, добавляется ряд пустых клеток. Итог: всегда 6 строк для цифр
                document.querySelector('#'+id+' tbody').innerHTML += '<tr><td> <td> <td> <td> <td> <td> <td> ' ;
            }
            }
            calendar("calendar", new Date().getFullYear(), new Date().getMonth());
            // переключатель минус месяц
                        document.querySelector('#calendar thead tr:nth-child(1) th:nth-child(1)').onclick = function() {
                            calendar("calendar", document.querySelector('#calendar thead th:nth-child(2)').dataset.year, parseFloat(document.querySelector('#calendar thead th:nth-child(2)').dataset.vMonth)-1);
                        }
            // переключатель плюс месяц
                        document.querySelector('#calendar thead tr:nth-child(1) th:nth-child(3)').onclick = function() {
                            calendar("calendar", document.querySelector('#calendar thead th:nth-child(2)').dataset.year, parseFloat(document.querySelector('#calendar thead th:nth-child(2)').dataset.vMonth)+1);
                        }
 
        </script>
 
        </div>
        </div>
    </div>
 
</body>
</html>
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
20.11.2018, 11:00
Помогаю со студенческими работами здесь

Bootstrap DatePicker вывод формата даты при смене даты
Привет, Поставил себе вот такой скрипт https://github.com/eternicode/bootstrap-datepicker ...

Как сделать так чтобы нажимая на картинку из одной формы открывалась другая при этом эта же картинка там же отображалась
Как сделать так чтобы нажимая на картинку из одной формы открывалась другая(как открывалась знаю) при этом эта же картинка там же...

Менять текст в блоке при смене слайда
http://wreality.ru/ с помощью, чего при смене слайда менять текст в блоке?

Как при смене темы менять стили кнопок?
В приложении используются 2 вида кнопок. Это разные кнопки как по цвету, так и по другим свойствам. Свойства этих 2-х видов кнопок...

При смене раскладки клавиатуры менять значение в label
На форме label. Как при смене раскладки клавиатуры (то есть при нажатии на Shift+Alt) сменить раскладку клавиатуры и в label написать...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
влияние грибов на сукцессию
anaschu 26.01.2026
Бифуркационные изменения массы гриба происходят тогда, когда мы уменьшаем массу компоста в 10 раз, а скорость прироста биомассы уменьшаем в три раза. Скорость прироста биомассы может уменьшаться за. . .
Воспроизведение звукового файла с помощью SDL3_mixer при касании экрана Android
8Observer8 26.01.2026
Содержание блога SDL3_mixer - это библиотека я для воспроизведения аудио. В отличие от инструкции по добавлению текста код по проигрыванию звука уже содержится в шаблоне примера. Нужно только. . .
Установка Android SDK, NDK, JDK, CMake и т.д.
8Observer8 25.01.2026
Содержание блога Перейдите по ссылке: https:/ / developer. android. com/ studio и в самом низу страницы кликните по архиву "commandlinetools-win-xxxxxx_latest. zip" Извлеките архив и вы увидите. . .
Вывод текста со шрифтом TTF на Android с помощью библиотеки SDL3_ttf
8Observer8 25.01.2026
Содержание блога Если у вас не установлены Android SDK, NDK, JDK, и т. д. то сделайте это по следующей инструкции: Установка Android SDK, NDK, JDK, CMake и т. д. Сборка примера Скачайте. . .
Использование SDL3-callbacks вместо функции main() на Android, Desktop и WebAssembly
8Observer8 24.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
моя боль
iceja 24.01.2026
Выложила интерполяцию кубическими сплайнами www. iceja. net REST сервисы временно не работают, только через Web. Написала за 56 рабочих часов этот сайт с нуля. При помощи perplexity. ai PRO , при. . .
Модель сукцессии микоризы
anaschu 24.01.2026
Решили писать научную статью с неким РОманом
http://iceja.net/ математические сервисы
iceja 20.01.2026
Обновила свой сайт http:/ / iceja. net/ , приделала Fast Fourier Transform экстраполяцию сигналов. Однако предсказывает далеко не каждый сигнал (см ограничения http:/ / iceja. net/ fourier/ docs ). Также. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru