Javascript.RU

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

Можно решить по другому, вот код второго блока, а в первом блоке можно просто присвоить дисплей ноне всем элементам с классом grig, и заменить фразу Православная пасха на Пасха

<div class="grig>
        Католическая пасха<br>
        <span class="grig">
        <span id="Catholic_Easter_gr"></span><br>
        по григорианскому календарю (новый стиль)<br>
        </span>
        <span class="ulian">
        <span id="Catholic_Easter_ul"></span><br>
        по юлианскому календарю (старый стиль)
        </span>
        </div>
        <div>
        Православная пасха<br> // В первом блоке заменить на Пасха
        <span class="grig">
        <span id="Orthodox_Easter_gr"></span><br>
        по григорианскому календарю (новый стиль)<br>
        </span>
        <span class="ulian">
        <span id="Orthodox_Easter_ul"></span><br>
        по юлианскому календарю (старый стиль)
        </span>
        </div>
        <div>
        Радуница<br>
        <span class="grig">
        <span id="Orthodox_Radunitsa_gr"></span><br>
        по григорианскому календарю (новый стиль)<br>
        </span>
        <span class="ulian">
        <span id="Orthodox_Radunitsa_ul"></span><br>
        по юлианскому календарю (старый стиль)
        </span>
        </div>
        <div>
        Вербное воскресенье<br>
        <span class="grig">
        <span id="palm_Sunday_Orthodox_gr"></span><br>
        по григорианскому календарю (новый стиль)<br>
        </span>
        <span class="ulian">
        <span id="palm_Sunday_Orthodox_ul"></span><br>
        по юлианскому календарю (старый стиль)
        </span>
        </div>
        <div>
        Масленица<br>
        <span class="grig">
        <span id="Maslenitsa_Orthodox_gr"></span><br>
        по григорианскому календарю (новый стиль)<br>
        </span>
        <span class="ulian">
        <span id="Maslenitsa_Orthodox_ul"></span><br>
        по юлианскому календарю (старый стиль)
        </span>
        </div>


другими словами этот код разместить для периода 326-4099, но добавив что если период 326-1582 то скрыть все элементы с классом grig, и заменить фразу 'Православная пасха' на слово 'Пасха'.
Ответить с цитированием
  #82 (permalink)  
Старый 08.12.2019, 12:55
Аватар для Malleys
Профессор
Отправить личное сообщение для Malleys Посмотреть профиль Найти все сообщения от Malleys
 
Регистрация: 20.12.2009
Сообщений: 1,714

Сообщение от laimas
И форматируйте код свой, чай вы же не главы из ветхого завета выставляете, а не форматированный код очень сложно читать.
А вот здесь хотелось бы узнать, почему вдруг неожиданно к определённому тексту нельзя применять форматирование?

Сообщение от laimas
if (year >= 300 && year <= 499) razn = 1;
    else if (year >= 500 && year <= 599) razn = 2;
    else if (year >= 600 && year <= 699) razn = 3;
    else if (year >= 700 && year <= 899) razn = 4;
    else if (year >= 900 && year <= 999) razn = 5;
    else if (year >= 1000 && year <= 1099) razn = 6;
    else if (year >= 1100 && year <= 1299) razn = 7;
    else if (year >= 1300 && year <= 1399) razn = 8;
    else if (year >= 1400 && year <= 1499) razn = 9;
    else if (year >= 1500 && year <= 1699) razn = 10;
    else if (year >= 1700 && year <= 1799) razn = 11;
    else if (year >= 1800 && year <= 1899) razn = 12;
    else if (year >= 1900 && year <= 2099) razn = 13;
    else if (year >= 2100 && year <= 2199) razn = 14;
    else if (year >= 2200 && year <= 2299) razn = 15;
    else if (year >= 2300 && year <= 2399) razn = 16;
    else if (year >= 2500 && year <= 2599) razn = 17;
    else if (year >= 2600 && year <= 2699) razn = 18;
    else if (year >= 2700 && year <= 2899) razn = 19;
    else if (year >= 2900 && year <= 2999) razn = 20;
    else if (year >= 3000 && year <= 3099) razn = 21;
    else if (year >= 3100 && year <= 3299) razn = 22;
    else if (year >= 3300 && year <= 3399) razn = 23;
    else if (year >= 3400 && year <= 3499) razn = 24;
    else if (year >= 3500 && year <= 3699) razn = 25;
    else if (year >= 3700 && year <= 3799) razn = 26;
    else if (year >= 3800 && year <= 3899) razn = 27;
    else if (year >= 3900 && year <= 4099) razn = 28;
Вам кажется и математику использовать нельзя? Этот кусок можно заменить на...
razn = - 2 + Math.floor(year / 100) - Math.floor(year / 400);


Сообщение от Блондинка
P. S. а в ветхом завете я понимаю ещё меньше чем в яваскрипт...
laimas разбирается в этом не более вас, а то всё противоречит сам себе!

Сообщение от laimas
Из ветхого:
И что вдруг потянуло на ветхие русские слова? Сейчас в русском языке для этого есть слово — старый. Но то, что вы скопировали, никакого отношения к понятию старый не имеет. Это называется — Псалмы, Пророки и Закон, или более кратко — Писания, а если нужно уточнить — Еврейские Писания.
Ответить с цитированием
  #83 (permalink)  
Старый 08.12.2019, 15:31
Профессор
Отправить личное сообщение для laimas Посмотреть профиль Найти все сообщения от laimas
 
Регистрация: 14.01.2015
Сообщений: 12,990

Сообщение от Malleys
И что вдруг потянуло на ветхие русские слова?
Послать? Я вяжу.
Ответить с цитированием
  #84 (permalink)  
Старый 08.12.2019, 17:40
Профессор
Отправить личное сообщение для laimas Посмотреть профиль Найти все сообщения от laimas
 
Регистрация: 14.01.2015
Сообщений: 12,990

Сообщение от Блондинка
Можно решить по другому
Все можно, но вот как понять это:

document.getElementById("Catholic_Easter_gr").innerHTML = formatDate(catholicDate(year)); // во втором
document.getElementById("Catholic_Easter_gr").innerHTML = formatDate(date0_1); // во втором


если

var date0_1 = catholicDate(year);
    document.getElementById("Catholic_Easter_gr").innerHTML = formatDate(date0_1);
 
    var date1_1 = new Date(date1.getFullYear(), date1.getMonth(), date1.getDate() + razn);
    document.getElementById("Orthodox_Easter_gr").innerHTML = formatDate(date1_1);


Зачем тогда сначала получается catholicDate(year), помещается в "Catholic_Easter_gr", затем из этой даты формируется новая, с коррекцией дня на razn, и затем опять помещается в "Catholic_Easter_gr"? Если бы этот объект был в двух блоках и первое действо было для первого блока, а второе для второго, тогда бы еще можно было понять, иначе я не понимаю.

Последний раз редактировалось laimas, 08.12.2019 в 17:42.
Ответить с цитированием
  #85 (permalink)  
Старый 09.12.2019, 07:52
Аватар для Блондинка
Профессор
Отправить личное сообщение для Блондинка Посмотреть профиль Найти все сообщения от Блондинка
 
Регистрация: 24.02.2019
Сообщений: 806

Сообщение от laimas Посмотреть сообщение
Все можно, но вот как понять это:

document.getElementById("Catholic_Easter_gr").innerHTML = formatDate(catholicDate(year)); // во втором
document.getElementById("Catholic_Easter_gr").innerHTML = formatDate(date0_1); // во втором


если

var date0_1 = catholicDate(year);
    document.getElementById("Catholic_Easter_gr").innerHTML = formatDate(date0_1);
 
    var date1_1 = new Date(date1.getFullYear(), date1.getMonth(), date1.getDate() + razn);
    document.getElementById("Orthodox_Easter_gr").innerHTML = formatDate(date1_1);


Зачем тогда сначала получается catholicDate(year), помещается в "Catholic_Easter_gr", затем из этой даты формируется новая, с коррекцией дня на razn, и затем опять помещается в "Catholic_Easter_gr"? Если бы этот объект был в двух блоках и первое действо было для первого блока, а второе для второго, тогда бы еще можно было понять, иначе я не понимаю.
Я объясняла, что с моими 'знаниями' в яваскрипт, у меня получилось только так

Сообщение от laimas Посмотреть сообщение
Очень понятно. )

document.getElementById("Catholic_Easter_gr").innerHTML = formatDate(catholicDate(year));

а здесь, еще раз просто catholicDate(year)

var date0_1 = catholicDate(year);

и

document.getElementById("Catholic_Easter_gr").innerHTML = formatDate(date0_1);

Почему, что есть что здесь не понять.
у меня просто по другому не получилось получить Catholic_Easter_ul
Ответить с цитированием
  #86 (permalink)  
Старый 09.12.2019, 08:47
Профессор
Отправить личное сообщение для laimas Посмотреть профиль Найти все сообщения от laimas
 
Регистрация: 14.01.2015
Сообщений: 12,990

Блондинка, я правда не понимаю чего вы хотите. По коду явно что-то лишнее и чтобы это стало понятно все можно представить так - у вас есть шкатулка (в коде это document.getElementById("Catholic_Easter_gr")), в которую можно поместить только одну пуговицу. И вот что вы делаете:

1) Вы берете пуговицу (catholicDate(year)), пусть это будет белая (date0_1), и кладете в шкатулку (innerHTML).

2) Затем вы хотите эту же пуговицу покрасить в черный цвет (new Date(date1.getFullYear(), date1.getMonth(), date1.getDate() + razn)), после как черную (date1_1) положить тоже в шкатулку.

Но по условию в шкатулку можно поместить только одну пуговицу. Вопрос - какую же пуговицу вы хотите положить в шкатулку, белую или черную?

А я, сторонний наблюдатель этого, могу только гадать: а) дама явно не понимает чего хочет; б) дама понимает чего хочет, но запамятовала, что у нее одна шкатулка; в) у дамы две шкатулки, но она забыла достать вторую с полки; г) ... ?
Ответить с цитированием
  #87 (permalink)  
Старый 09.12.2019, 11:18
Аватар для Блондинка
Профессор
Отправить личное сообщение для Блондинка Посмотреть профиль Найти все сообщения от Блондинка
 
Регистрация: 24.02.2019
Сообщений: 806

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

в этом посте надо от католической даты отнять разницу и получить католическую дату по старому стилю
Ответить с цитированием
  #89 (permalink)  
Старый 09.12.2019, 12:19
Профессор
Отправить личное сообщение для laimas Посмотреть профиль Найти все сообщения от laimas
 
Регистрация: 14.01.2015
Сообщений: 12,990

В общем после кучи всяких условий и "хочу", вот так, как последнее, но не с ID, ибо это дубликаты, а значит уйдет не тому кому адресовано, а с классами. Далее проверяйте сами так или нет, но это все ваше, изменяйте, переставляйте ...

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<style>
div.box-range > div, .input { width: 70%; border: 1px solid #a9a9a9; border-radius: 12px/9px; padding: 10px 25px; margin: 0 20px 5px 0; }
span.ulian { color: hsl(240,100%,70%); }
span.grig { color: hsl(240,100%,30%); }
input { display: inline-block; text-align: center; }
</style>
</head>
<body>

<div class="input">
    <input id="YearEntry" type="number" min="326" max="4099" step="1" value="2019" />
    <input id="button1" type="button" value="Расcчитать" />
</div>

<div class="box-range" range="[0,325]">
    <div>Первый Никейский собор — собор Церкви, созванный императором Константином I; состоялся в июне 325 года в городе Никее (ныне Изник, Турция); 
        продолжался больше двух месяцев и стал первым Вселенским собором в истории христианства.<br>
        Введите год с 326 по 4099
    </div>
</div>

<div class="box-range" range="[326,1582]">
    <div>
        Пасха<br>
        <span class="ulian">
        <span class="Orthodox_Easter_ul"></span><br>
        по юлианскому календарю (старый стиль)
        </span>
    </div>
    <div>
        Радуница<br>
        <span class="ulian">
        <span class="Orthodox_Radunitsa_ul"></span><br>
        по юлианскому календарю (старый стиль)
        </span>
    </div>
    <div>
        Вербное воскресенье<br>
        <span class="ulian">
        <span class="palm_Sunday_Orthodox_ul"></span><br>
        по юлианскому календарю (старый стиль)
        </span>
    </div>
    <div>
        Масленица<br>
        <span class="ulian">
        <span class="Maslenitsa_Orthodox_ul"></span><br>
        по юлианскому календарю (старый стиль)
        </span>
    </div>
</div>

<div class="box-range" range="[1583,4099]">
    <div>
        Католическая пасха<br>
        <span class="grig">
        <span class="Catholic_Easter_gr"></span><br>
        по григорианскому календарю (новый стиль)<br>
        </span>
        <span class="ulian">
        <span class="Catholic_Easter_ul"></span><br>
        по юлианскому календарю (старый стиль)
        </span>
    </div>
    <div>
        Православная пасха<br>
        <span class="grig">
        <span class="Orthodox_Easter_gr"></span><br>
        по григорианскому календарю (новый стиль)<br>
        </span>
        <span class="ulian">
        <span class="Orthodox_Easter_ul"></span><br>
        по юлианскому календарю (старый стиль)
        </span>
    </div>
    <div>
        Радуница<br>
        <span class="grig">
        <span class="Orthodox_Radunitsa_gr"></span><br>
        по григорианскому календарю (новый стиль)<br>
        </span>
        <span class="ulian">
        <span class="Orthodox_Radunitsa_ul"></span><br>
        по юлианскому календарю (старый стиль)
        </span>
    </div>
    <div>
        Вербное воскресенье<br>
        <span class="grig">
        <span class="palm_Sunday_Orthodox_gr"></span><br>
        по григорианскому календарю (новый стиль)<br>
        </span>
        <span class="ulian">
        <span class="palm_Sunday_Orthodox_ul"></span><br>
        по юлианскому календарю (старый стиль)
        </span>
    </div>
    <div>
        Масленица<br>
        <span class="grig">
        <span class="Maslenitsa_Orthodox_gr"></span><br>
        по григорианскому календарю (новый стиль)<br>
        </span>
        <span class="ulian">
        <span class="Maslenitsa_Orthodox_ul"></span><br>
        по юлианскому календарю (старый стиль)
        </span>
    </div>
</div>

<div class="box-range" range="[4100,0]">
    <div>Введите год с 326 по 4099</div>
</div>

<script>
var inputY = document.getElementById("YearEntry");
    
inputY.value = new Date().getFullYear();
    
inputY.addEventListener("keyup", function() {
    this.value = this.value.replace(/\D/, '');
    showBox();
});
    
inputY.addEventListener("change", showBox);
    
document.getElementById("button1").addEventListener("click", getEaster);

showBox();
getEaster();

function catholicDate(year) {
    // https://ru.wikipedia.org/wiki/Алгоритм_Гаусса_вычисления_даты_Пасхи
    // Пример на 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);
}

function orthodoxDate(year) {
    // https://ru.wikipedia.org/wiki/Алгоритм_Гаусса_вычисления_даты_Пасхи
    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);
}

// Все даты отображаем в едином формате
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>'
    });
}

function showBox() {
    var Y = +inputY.value || 0, 
        box = document.querySelectorAll(".box-range"), 
        i, range, a;
    
    for(i=0; i<box.length; ++i) {
        range = JSON.parse(box[i].getAttribute('range')); 
        a = [];
        if(range[0]) a.push(Y >= range[0]);
        if(range[1]) a.push(Y <= range[1]);
        box[i].hidden = !eval(a.join('&&'))
    }
}

function getEaster() {
    var year = inputY.value, 
        razn = 0, //какое-то значение по умолчанию если меньше 300 и больше 4099
        box = document.querySelectorAll(".box-range"),
        dt, easter = {}, i, k;
        
    if (year >= 300 && year <= 499) razn = 1;
    else if (year >= 500 && year <= 599) razn = 2;
    else if (year >= 600 && year <= 699) razn = 3;
    else if (year >= 700 && year <= 899) razn = 4;
    else if (year >= 900 && year <= 999) razn = 5;
    else if (year >= 1000 && year <= 1099) razn = 6;
    else if (year >= 1100 && year <= 1299) razn = 7;
    else if (year >= 1300 && year <= 1399) razn = 8;
    else if (year >= 1400 && year <= 1499) razn = 9;
    else if (year >= 1500 && year <= 1699) razn = 10;
    else if (year >= 1700 && year <= 1799) razn = 11;
    else if (year >= 1800 && year <= 1899) razn = 12;
    else if (year >= 1900 && year <= 2099) razn = 13;
    else if (year >= 2100 && year <= 2199) razn = 14;
    else if (year >= 2200 && year <= 2299) razn = 15;
    else if (year >= 2300 && year <= 2399) razn = 16;
    else if (year >= 2500 && year <= 2599) razn = 17;
    else if (year >= 2600 && year <= 2699) razn = 18;
    else if (year >= 2700 && year <= 2899) razn = 19;
    else if (year >= 2900 && year <= 2999) razn = 20;
    else if (year >= 3000 && year <= 3099) razn = 21;
    else if (year >= 3100 && year <= 3299) razn = 22;
    else if (year >= 3300 && year <= 3399) razn = 23;
    else if (year >= 3400 && year <= 3499) razn = 24;
    else if (year >= 3500 && year <= 3699) razn = 25;
    else if (year >= 3700 && year <= 3799) razn = 26;
    else if (year >= 3800 && year <= 3899) razn = 27;
    else if (year >= 3900 && year <= 4099) razn = 28;

    dt = catholicDate(year);
    
    easter.Catholic_Easter_gr = formatDate(dt);
    
    dt = new Date(dt.getFullYear(), dt.getMonth(), dt.getDate() - razn);
    
    easter.Catholic_Easter_ul = formatDate(dt);
    
    dt = orthodoxDate(year); //date1
    
    easter.Orthodox_Easter_ul = formatDate(dt); 
    
    easter.Orthodox_Radunitsa_ul = formatDate(new Date(dt.getFullYear(), dt.getMonth(), dt.getDate() + 9));
    
    easter.palm_Sunday_Orthodox_ul = formatDate(new Date(dt.getFullYear(), dt.getMonth(), dt.getDate() - 7));
    
    easter.Maslenitsa_Orthodox_ul = formatDate(new Date(dt.getFullYear(), dt.getMonth(), dt.getDate() - 49));
    
    dt = new Date(dt.getFullYear(), dt.getMonth(), dt.getDate() + razn); //date1_1
    
    easter.Orthodox_Easter_gr = formatDate(dt);
    
    easter.Orthodox_Radunitsa_gr = formatDate(new Date(dt.getFullYear(), dt.getMonth(), dt.getDate() + 9));
    
    easter.palm_Sunday_Orthodox_gr = formatDate(new Date(dt.getFullYear(), dt.getMonth(), dt.getDate() - 7));
    
    easter.Maslenitsa_Orthodox_gr = formatDate(new Date(dt.getFullYear(), dt.getMonth(), dt.getDate() - 49));
    
    
    for(i=0; i<box.length; ++i) {
        if(!box[i].hidden) {
            razn = box[i].querySelectorAll(".ulian");
            for(k=0; k<razn.length; ++k) {
                dt = razn[k].querySelector("span");
                dt.innerHTML = easter[dt.className];
            }
        }
    }
}
</script>
</body>
</html>

Последний раз редактировалось laimas, 09.12.2019 в 15:24.
Ответить с цитированием
  #90 (permalink)  
Старый 09.12.2019, 12:54
Аватар для Блондинка
Профессор
Отправить личное сообщение для Блондинка Посмотреть профиль Найти все сообщения от Блондинка
 
Регистрация: 24.02.2019
Сообщений: 806

все даты по григорианскому календарю не отображаются, а по юлианскому отображаются
Ответить с цитированием
Ответ



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

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


Похожие темы
Тема Автор Раздел Ответов Последнее сообщение
Как сделать чтобы кнопка «Назад» работала бы в пределах определенного сайта? 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