:cray:
|
Цитата:
Цитата:
Цитата:
|
если честно... то всё непонятно...
|
Везде где вызывается эта функция:
textContent = formatDate возвращаемое ею значение вставляется в элементы как textContent, что будет трактоваться обычной строкой, поэтому и выводит у вас <br>. А чтобы это трактовалось как html, его нужно определять для innerHTML элемента, то есть везде textContent = formatDate заменить на innerHTML = formatDate Надеюсь понятно, что все что перед textContent и после formatDate написанное у вас я просто опустил. |
laimas, :thanks:
Вот сейчас работает <!DOCTYPE html> <html> <head> <meta charset="utf-8" /> <style> div { width: 70%; border: 1px solid #a9a9a9; border-radius: 12px/9px; padding: 10px 25px; margin: 0 20px 5px 0; } input { display: inline-block; text-align: center; } </style> </head> <body> <div> <input id="YearEntry" type="number" min="326" max="4099" step="1" value="2019" /> <input id="button1" type="button" value="Расcчитать" /> </div> <div> Католическая пасха<br /> <span id="catholic"></span> </div> <div> Православная пасха<br /> <span id="orthodox"></span> </div> <div> Радуница<br /> <span id="rad"></span> </div> <div> Вербное воскресенье<br /> <span id="verb"></span> </div> <div> Масленица<br /> <span id="masl"></span> </div> <script> function catholicDate(year) { // https://ru.wikipedia.org/wiki/Алгоритм_Гаусса_вычисления_даты_Пасхи // Пример на 1777 год (год рождения Карла Гаусса): год = 1777 // a = год mod 19 a = 10 var a = year % 19; // b = год mod 4 b = 1 var b = year % 4; // c = год mod 7 c = 6 var c = year % 7; // k = целая часть (год/100) k = 17 var k = Math.floor(year / 100); // p = целая часть ((13 + 8k)/25) p = 5 var p = Math.floor((13 + 8 * k) / 25); // q = целая часть (k/4) q = 4 var q = Math.floor(k / 4); // M = (15 в€’ p + k в€’ q) mod 30 M = 23 var m = (15 - p + k - q) % 30; // N = (4 + k в€’ q) mod 7 N = 3 var n = (4 + k - q) % 7; // d = (19a + M) mod 30 d = 3 var d = (19 * a + m) % 30; // e = (2b + 4c + 6d + N) mod 7 e = 5 var e = (2 * b + 4 * c + 6 * d + n) % 7; // Дата Пасхи по новому стилю: 22 + d + e марта или d + e в€’ 9 апреля 30 марта // Если d = 29 и e = 6, то вместо 26 апреля будет 19 апреля if (d === 29 && e === 6) return new Date(year, 3, 19); // Если d = 28, e = 6 и (11M + 11) mod 30 < 19, то вместо 25 апреля будет 18 апреля if (d === 28 && e === 6 && ((11 * m + 11) % 30 < 19)) return new Date(year, 3, 18); if (d + e > 9) return new Date(year, 3, d + e - 9); else return new Date(year, 2, 22 + d + e); } function orthodoxDate(year) { // https://ru.wikipedia.org/wiki/Алгоритм_Гаусса_вычисления_даты_Пасхи // Разделить номер года на 19 и определить остаток от деления a. var a = year % 19; // Разделить номер года на 4 и определить остаток от деления b. var b = year % 4; // Разделить номер года на 7 и определить остаток от деления c. var c = year % 7; // Разделить сумму 19a + 15 на 30 и определить остаток d. var d = (19 * a + 15) % 30; // Разделить сумму 2b + 4c + 6d + 6 на 7 и определить остаток e. var e = (2 * b + 4 * c + 6 * d + 6) % 7; // Определить сумму f = d + e. var f = d + e; // (по старому стилю) Если f ≤ 9, то Пасха будет праздноваться 22 + f марта; если f > 9, то Пасха будет праздноваться f — 9 апреля. // (по новому стилю) Если f ≤ 26, то Пасха будет праздноваться 4 + f апреля; если f > 26, то Пасха будет праздноваться f — 26 мая. return f <= 26 ? new Date(year, 3, 4 + f) : new Date(year, 4, f - 26); } // Все даты отображаем в едином формате function formatDate(date) { return date.toLocaleDateString("ru", { weekday: "long", day: "numeric", month: "long", year: "numeric" }).replace(/^.?|,/g, function(v, i) { return !i ? v.toUpperCase() : '<br>' }); } document.addEventListener("DOMContentLoaded", document_domcontentloaded); function document_domcontentloaded(){ document.getElementById("YearEntry").value = new Date().getFullYear(); button1_click(); document.getElementById("button1").onclick = button1_click; } function button1_click() { var year = document.getElementById("YearEntry").value; document.getElementById("catholic").innerHTML = formatDate(catholicDate(year)); var date1 = orthodoxDate(year); document.getElementById("orthodox").innerHTML = formatDate(date1); var date2 = new Date(date1.getFullYear(), date1.getMonth(), date1.getDate() + 9); document.getElementById("rad").innerHTML = formatDate(date2); var date3 = new Date(date1.getFullYear(), date1.getMonth(), date1.getDate() - 7); document.getElementById("verb").innerHTML = formatDate(date3); var date4 = new Date(date1.getFullYear(), date1.getMonth(), date1.getDate() - 49); document.getElementById("masl").innerHTML = formatDate(date4); } </script> </body> </html> |
А почему не так?
return date.toLocaleDateString("ru", { weekday: "long", day: "numeric", month: "long", year: "numeric" }).replace(/^.?|,/g, (v, i) => i ? '<br>' : v.toUpperCase()) |
Сейчас осталось разобраться как получить даты и по старому и по новому стилям, и как выводить на экран или одну дату по старому стилю(если дата меньше 15 окт 1582г.), или две даты по обоим стилям
|
Цитата:
|
Цитата:
function f(d){return d.toLocaleDateString("ru",{weekday:"long",day:"numeric",month:"long",year:"numeric"}).replace(/^.?|,/g,function(a,b){return b?"<br>":a.toUpperCase()})}document.addEventListener("DOMContentLoaded",l);function l(){document.getElementById("YearEntry").value=(new Date).getFullYear();p();document.getElementById("button1").onclick=p}function p(){var d=document,a=d.getElementById("YearEntry").value;var b=(a%19*19+15)%30;b+=(a%4*2+a%7*4+6*b+6)%7;b=26>=b?new Date(a,3,4+b):new Date(a,4,b-26);var g=b.getFullYear(),h=b.getMonth(),k=b.getDate(),c=Math.floor(a/100),m=Math.floor(c/4),n=(15-Math.floor((13+8*c)/25)+c-m)%30,e=(a%19*19+n)%30;c=(a%4*2+a%7*4+6*e+(4+c-m)%7)%7;d.getElementById("catholic").innerHTML=f(29===e&&6===c?new Date(a,3,19):28===e&&6===c&&19>(11*n+11)%30?new Date(a,3,18):9<e+c?new Date(a,3,e+c-9):new Date(a,2,22+e+c));d.getElementById("orthodox").innerHTML=f(b);d.getElementById("rad").innerHTML=f(new Date(g,h,k+9));d.getElementById("verb").innerHTML=f(new Date(g,h,k-7));d.getElementById("masl").innerHTML=f(new Date(g,h,k-49))}; А версию разработчика держать отдельно. |
laimas,
может быть подскажешь как вывести на экран если дата меньше 15 окт 1582 г. <div>Католическая пасха:<br> Воскресенье<br> число месяц год (по старому стилю)</div> а если равна или больше, то <div>Католическая пасха <br> :Воскресенье<br> число месяц год (по новому стилю)<br> Воскресенье<br> число месяц год (по старому стилю)</div> и так с каждой датой |
Часовой пояс GMT +3, время: 13:34. |