Javascript.RU

Создать новую тему Ответ
 
Опции темы Искать в теме
  #121 (permalink)  
Старый 22.04.2021, 23:51
Аватар для Блондинка
Профессор
Отправить личное сообщение для Блондинка Посмотреть профиль Найти все сообщения от Блондинка
 
Регистрация: 24.02.2019
Сообщений: 806

кто может помочь совместить два скрипт?

есть функция
function catholicDate(year) {
        // [url]https://ru.wikipedia.org/wiki/Алгоритм_Гаусса_вычисления_даты_Пасхи[/url]
        // Пример на 1777 год (год рождения Карла Гаусса): год = 1777
        var a = year % 19,
        b = year % 4,
        c = year % 7,
        k = Math.floor(year / 100),
        p = Math.floor((13 + 8 * k) / 25),
        q = Math.floor(k / 4),
        m = (15 - p + k - q) % 30,
        n = (4 + k - q) % 7,
        d = (19 * a + m) % 30,
        e = (2 * b + 4 * c + 6 * d + n) % 7;
        if (d === 29 && e === 6) return new Date(year, 3, 19);
        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);
        }

с помощью которой получаем дату католический пасхи,
далее надо получить даты других католических праздников
0.) (span class Catholic_Easter_gr и Catholic_Easter_ul)
1.) Масленица (-49 дней) (span class Maslenitsa_Catholic_gr и Maslenitsa_Catholic_ul)
2.) Вербное воскресенье (-7 дней) (span class palm_Sunday_Catholic_gr и palm_Sunday_Catholic_ul)
3.) Радуница (+9дней) (span class Catholic_Radunitsa_gr и Catholic_Radunitsa_ul)
4.) Троица (+49 дней) (span class Catholic_Trinity_gr и Catholic_Trinity_ul)

потом надо высчитать даты всех этих праздников по юлианскому календарю, и высчитать дни недели по юлианскому календарю и вывести на экран текстом...

далее есть функция
// [url]https://ru.wikipedia.org/wiki/Алгоритм_Гаусса_вычисления_даты_Пасхи[/url]
        var a = year % 19,
        b = year % 4,
        c = year % 7,
        d = (19 * a + 15) % 30,
        e = (2 * b + 4 * c + 6 * d + 6) % 7,
        f = d + e;
        // (по старому стилю) Если f ≤ 9, то Пасха будет праздноваться 22 + f марта; если f > 9, то Пасха будет праздноваться f — 9 апреля.
        return f <= 9 ? new Date(year, 2, 22 + f) : new Date(year, 3, f - 9);
        }

с помощью которой получаем дату православной пасхи по юлианскому календарю,
далее надо получить даты других православных праздников
0.) (span class Orthodox_Easter_gr и Orthodox_Easter_ul)
1.) Масленица (-49 дней) (span class Maslenitsa_Orthodox_gr и Maslenitsa_Orthodox_gr)
2.) Вербное воскресенье (-7 дней) (span class palm_Sunday_Orthodox_gr и palm_Sunday_Orthodox_ul)
3.) Радуница (+9дней) (span class Orthodox_Radunitsa_gr и Orthodox_Radunitsa_ul)
4.) Троица (+49 дней) (span class Orthodox_Trinity_gr и Orthodox_Trinity_ul)

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

высчитытывать даты по другим календарям нужно с помощью функций из следующего скрипта
document.addEventListener('DOMContentLoaded', function () {
// [url]https://en.wikipedia.org/wiki/Julian_day#Julian_day_number_calculation[/url]
// The algorithms are valid for JDN >= 0, Gregorian >= 24.11.-4713, Julian >= 01.01.-4712
function gregorianToJdn(d, m, y) {
    return tr((1461 * (y + 4800 + tr((m - 14) / 12))) / 4) +
           tr((367 * (m - 2 - 12 * tr((m - 14) / 12))) / 12) -
           tr((3 * tr((y + 4900 + tr((m - 14) / 12)) / 100)) / 4) + d - 32075;
}
function julianToJdn(d, m, y) {
    return 367 * y - tr((7 * (y + 5001 + tr((m - 9) / 7))) / 4) + tr((275 * m) / 9) + d + 1729777;
}
function jdnToJulianOrGregorian(j, to) { // to: true (julian), false (gregorian)
    var f = (to) ? (j + 1401) : (j + 1363 + tr((tr((4 * j + 274277) / 146097) * 3) / 4));
    var e = 4 * f + 3, h = 5 * tr((e % 1461) / 4) + 2;
    var d = tr((h % 153) / 5) + 1, m = ((tr(h / 153) + 2) % 12) + 1, y = tr(e / 1461) - 4716 + tr((14 - m) / 12);
    return { d: d, m: m, y: y };
}
function jdnToWeekDay(j) { return (j % 7) + 1; }
function tr(n) { return n - n % 1; } // truncate (for integer division)
// -- wiki end --
var C = document.converter;
// options
var wdays = ['Понедельник','Вторник','Среда','Четверг','Пятница','Суббота','Воскресенье'];
for (var o = '', i = 0; i < wdays.length; i++) o += '<option value="' + (i + 1) + '">' + wdays[i] + '</option>';
C.gwDay.innerHTML = C.jwDay.innerHTML = o;
for (var o = '', i = 1; i <= 31; i++) o += '<option value="' + i  + '">' + i + '</option>';
C.gDay.innerHTML = C.jDay.innerHTML = o;
var months = ['января','февраля','марта','апреля','мая','июня','июля','августа','сентября','октября','ноября','декабря'];
for (var o = '', i = 0; i < months.length; i++) o += '<option value="' + (i + 1) + '">' + months[i] + '</option>';
C.gMonth.innerHTML = C.jMonth.innerHTML = o;
var eras = ['н. э.','до н. э.'], _eras = ['ce','bce'];
for (var o = '', i = 0; i < eras.length; i++) o += '<option value="' + _eras[i] + '">' + eras[i] + '</option>';
C.gEra.innerHTML = C.jEra.innerHTML = o;
// -- options end --
C.gCalc.onclick = function () {
    var gd = +C.gDay.value, gm = +C.gMonth.value, gy = historicalToAstronomical(+C.gYear.value, C.gEra.value);
    var jdn = gregorianToJdn(gd, gm, gy), wd = jdnToWeekDay(jdn), jd = jdnToJulianOrGregorian(jdn, true);
    var jy = astronomicalToHistorical(jd.y);
    C.gwDay.value = C.jwDay.value = wd, C.jDay.value = jd.d, C.jMonth.value = jd.m, C.jYear.value = jy.y, C.jEra.value = jy.e;
    onUpdateAll(jdn);
};
C.jCalc.onclick = function () {
    var jd = +C.jDay.value, jm = +C.jMonth.value, jy = historicalToAstronomical(+C.jYear.value, C.jEra.value);
    var jdn = julianToJdn(jd, jm, jy), wd = jdnToWeekDay(jdn), gd = jdnToJulianOrGregorian(jdn, false);
    var gy = astronomicalToHistorical(gd.y);
    C.gwDay.value = C.jwDay.value = wd, C.gDay.value = gd.d, C.gMonth.value = gd.m, C.gYear.value = gy.y, C.gEra.value = gy.e;
    onUpdateAll(jdn);
};
function initDate(c, d, m, y, e) {
    if (d + m + y == 'now') { var n = new Date(); d = n.getDate(), m = n.getMonth() + 1, y = n.getFullYear(); }
    C[c + 'Day'].value = d, C[c + 'Month'].value = m, C[c + 'Year'].value = y, C[c + 'Era'].value = e;
    C[c + 'Calc'].onclick();
    }
    function historicalToAstronomical(y, e) { // e: 'ce', 'bce'
    e = (y < 1) ? 'bce' : e;
    return ((e == 'bce') && y > 0) ? (1 - y) : y;
    }
    function astronomicalToHistorical(y) {
    var e = (y < 1) ? 'bce' : 'ce';
    return { y: (e == 'bce') ? -(y - 1) : y, e: e };
    }
    for (var ess = C.querySelectorAll('.express'), es, i = 0; i < ess.length; i++) {
    es = ess[i], es.onclick = Function.prototype.apply.bind(initDate, null, es.value.split('_'));
    }
    // Express-url format ...?C=D_M_Y_E
    var m = location.search.match(/(j|g)=(\d+)_(\d+)_(\d+)_(ce|bce)/);
    if (m) { initDate(m[1], m[2], m[3], m[4], m[5]); } else { initDate('g', 'n', 'o', 'w', 'ce'); }
    function onUpdateAll(jdn) {
    console.log('JDN:', jdn);
    console.assert(jdn >= 2299161, 'Proleptic: Gn < 15.10.1582 CE');
    console.assert(jdn >= 1704987, 'Proleptic: Jn < 01.01.45 BCE');
    console.assert(jdn >= 0, 'Invalid: Gn < 24.11.4714 BCE, Jn < 01.01.4713 BCE');
    }
    });


и всё это высчитывается исходя из введённого в input года, по умолчанию стоит текущий (2021)

кто может это реализовать?
Ответить с цитированием
  #122 (permalink)  
Старый 23.04.2021, 07:03
Аватар для Блондинка
Профессор
Отправить личное сообщение для Блондинка Посмотреть профиль Найти все сообщения от Блондинка
 
Регистрация: 24.02.2019
Сообщений: 806

набросала приблизительно html
<style>
div { border: 1px solid #000; padding: 5px 20px; margin: 0 0 3px 0; }
input { border: 1px solid #999; display: inline-block; /* без свойства дисплей не во всех браузерах работает выравнивание в поле ввода */ text-align: center; }
</style>
<script> 
var d = new Date(); 
document.addEventListener('DOMContentLoaded', function() { 
document.querySelector('#year').value = d.getFullYear();
});
</script>
<div id="input">
<input id="Year" type="number" min="326" max="9999" step="1" value="" />
</div>
        
<div>Первый Никейский собор — собор Церкви, созванный императором Константином I; состоялся в июне 325 года в городе Никее (ныне Изник, Турция);
продолжался больше двух месяцев и стал первым Вселенским собором в истории христианства.<br>
Введите год с 326 по 9999
</div>

<div>Введите год с 326 по 9999</div>
    
    <div id="Catholic_Easter">
Католическая пасха<br>
<span id="Catholic_Easter_gr">
</span><br>
по григорианскому календарю (новый стиль)<br>
<span id="Catholic_Easter_ul">
</span><br>
по юлианскому календарю (старый стиль)
</div>

<div id="Maslenitsa_Catholic">
Католическая масленица<br>
<span id="Maslenitsa_Catholic_gr">
</span><br>
по григорианскому календарю (новый стиль)<br>
<span id="Maslenitsa_Catholic_ul">
</span><br>
по юлианскому календарю (старый стиль)
</div>

<div id="palm_Sunday_Catholic">
Католическое вербное воскресенье<br>
<span id="palm_Sunday_Catholic_gr">
</span><br>
по григорианскому календарю (новый стиль)<br>
<span id="palm_Sunday_Catholic_ul">
</span><br>
по юлианскому календарю (старый стиль)
</div>

<div id="Catholic_Radunitsa">
Католическая радуница<br>
<span id="Catholic_Radunitsa_gr">
</span><br>
по григорианскому календарю (новый стиль)<br>
<span id="Catholic_Radunitsa_ul">
</span><br>
по юлианскому календарю (старый стиль)
</div>

<div id="Catholic_Trinity">
Католическая троица<br>
<span id="Catholic_Trinity_gr">
</span><br>
по григорианскому календарю (новый стиль)<br>
<span id="Catholic_Trinity_ul">
</span><br>
по юлианскому календарю (старый стиль)
</div>

<div id="Orthodox_Easter">
Православная пасха<br>
<span id="Orthodox_Easter_gr">
</span><br>
по григорианскому календарю (новый стиль)<br>
<span id="Orthodox_Easter_ul">
</span><br>
по юлианскому календарю (старый стиль)
</div>

<div id="Maslenitsa_Orthodox">
Православная масленица<br>
<span id="Maslenitsa_Orthodox_gr">
</span><br>
по григорианскому календарю (новый стиль)<br>
<span id="Maslenitsa_Orthodox_ul">
</span><br>
по юлианскому календарю (старый стиль)
</div>

<div id="palm_Sunday_Orthodox">
Православное вербное воскресенье<br>
<span id="palm_Sunday_Orthodox_gr">
</span><br>
по григорианскому календарю (новый стиль)<br>
<span id="palm_Sunday_Orthodox_ul">
</span><br>
по юлианскому календарю (старый стиль)
</div>

<div id="Orthodox_Radunitsa">
Православная радуница<br>
<span id="Orthodox_Radunitsa_gr">
</span><br>
по григорианскому календарю (новый стиль)<br>
<span id="Orthodox_Radunitsa_ul">
</span><br>
по юлианскому календарю (старый стиль)
</div>

<div id="Orthodox_Trinity">
Православная троица<br>
<span id="Orthodox_Trinity_gr">
</span><br>
по григорианскому календарю (новый стиль)<br>
<span id="Orthodox_Trinity_ul">
</span><br>
по юлианскому календарю (старый стиль)
</div>
Ответить с цитированием
Ответ


Опции темы Искать в теме
Искать в теме:

Расширенный поиск


Похожие темы
Тема Автор Раздел Ответов Последнее сообщение
Как сделать чтобы кнопка «Назад» работала бы в пределах определенного сайта? Askeer Общие вопросы Javascript 0 12.10.2016 18:58
Как сделать поворот DIV клонов alexgrenn Элементы интерфейса 4 18.04.2016 21:58
filter(this,this) как правильно сделать? Smip jQuery 5 23.02.2013 03:07
Как сделать локальную переменную глобальной?? Дмитрий Общие вопросы Javascript 8 02.11.2010 03:33
Как обозначить переменную выбранную в FileChooser? woo_hoo Общие вопросы Javascript 4 03.07.2008 12:58