Javascript.RU

Создать новую тему Ответ
 
Опции темы Искать в теме
  #11 (permalink)  
Старый 10.04.2019, 12:35
Кандидат Javascript-наук
Отправить личное сообщение для Besprizornik Посмотреть профиль Найти все сообщения от Besprizornik
 
Регистрация: 24.02.2019
Сообщений: 109

Народ, кто может составить функцию которая будет отнимать/прибавлять к григорианской дате правильное количество дней, с учётом того что в юлианском календаре каждый четвёртый год високосный, а в григорианском года кратные 100 простые а кратные 400 високосные
Ответить с цитированием
  #12 (permalink)  
Старый 10.04.2019, 12:47
Кандидат Javascript-наук
Отправить личное сообщение для Besprizornik Посмотреть профиль Найти все сообщения от Besprizornik
 
Регистрация: 24.02.2019
Сообщений: 109

Вот код страницы вместе с таблицей

<!DOCTYPE html>
<html><head>
<meta charset=utf-8">
<title>Конвертирование даты из григорианского календаря в юлианский и обратно.</title>
<style>
body { color: #0000a0; font: 14px Georgia, 'Times New Roman', Times, serif; }
h1 { color: #ffffff; font: 16px Georgia, 'Times New Roman', Times, serif; text-shadow: 1px 1px #0005ff, -1px 1px #0005ff, 1px -1px #0005ff, -1px -1px #0005ff, 1px 0px #0005ff, 0px 1px #0005ff, -1px 0px #0005ff, 0px -1px #0005ff; -webkit-animation: h-pulsare 1.35s linear infinite; animation: h-pulsare 1.35s linear infinite;}
div { border: 1px solid #999999; padding: 10px; margin-bottom: 10px; min-width: 340px; width: 100%; }
div.date { white-space: nowrap; }
select { height: 26px; margin: 0; }
input { height: 22px; padding-left: 5px; }
select, input { background: #d7d7ff; color: #0000a0; border: 1px solid #0000a0; font: 16px Georgia, 'Times New Roman', Times, serif; line-height: 0; margin: 5px 3px; }
div.day-grig, div.day-ulian { display: block; padding: 0; margin: 0 auto -10px 2px; border: 1px solid transparent; width: 136px; height: 26px; position: relative; }
select.day_gr, select.day_ul { position: relative; bottom: 0px; right: 2px; margin: 0 auto -10px 2px; width: 136px; }
span.day_week { position: relative; right: 136.5px; font: 16px Georgia, 'Times New Roman', Times, serif; }
@-webkit-keyframes h-pulsare { 0%, 100% { color: #ffffff; text-shadow: 1px 1px #0005ff, -1px 1px #0005ff, 1px -1px #0005ff, -1px -1px #0005ff, 1px 0px #0005ff, 0px 1px #0005ff, -1px 0px #0005ff, 0px -1px #0005ff; } 50% { color: #d7d7ff; text-shadow: 1px 1px #0005ff, -1px 1px #0005ff, 1px -1px #0005ff, -1px -1px #0005ff, 1px 0px #0005ff, 0px 1px #0005ff, -1px 0px #0005ff, 0px -1px #0005ff, 0 0 30px #ff0055; } } @keyframes h-pulsare { 0%, 100% { color: #ffffff; text-shadow: 1px 1px #0005ff, -1px 1px #0005ff, 1px -1px #0005ff, -1px -1px #0005ff, 1px 0px #0005ff, 0px 1px #0005ff, -1px 0px #0005ff, 0px -1px #0005ff; } 50% { color: #d7d7ff; text-shadow: 1px 1px #0005ff, -1px 1px #0005ff, 1px -1px #0005ff, -1px -1px #0005ff, 1px 0px #0005ff, 0px 1px #0005ff, -1px 0px #0005ff, 0px -1px #0005ff, 0 0 30px #ff0055; } }
</style>
<script> 
var d = new Date(), dayweek = ['Воскресенье', 'Понедельник', 'Вторник', 'Среда', 'Четверг', 'Пятница', 'Суббота'][d.getDay()];
document.addEventListener('DOMContentLoaded', function() { 
[].forEach.call(document.querySelectorAll('.day_week'), function (el) { el.textContent = dayweek });
document.querySelector('#date_gr').options[d.getDate()].selected = true;
document.querySelector('#month_gr').options[d.getMonth()+1].selected = true;
document.querySelector('#year_gr').value = d.getFullYear();
document.querySelector('#era_gr').options.selected = true;
d.setDate(d.getDate() - 13);
document.querySelector('#date_ul').options[d.getDate()].selected = true;
document.querySelector('#month_ul').options[d.getMonth()+1].selected = true;
document.querySelector('#year_ul').value = d.getFullYear();
document.querySelector('#era_ul').options.selected = true;
});
</script>
</head><body>
<h1>Конвертирование даты из григорианского календаря в юлианский и обратно.</h1>
<div class="date">
Сегодня:<br/>
<div class="day-grig"><select class="day_gr" id="day_gr">
</select>
<span class="day_week"></span></div><br>
<select class="date_gr" id="date_gr">
<option value="1">01</option><option value="2">02</option><option value="3">03</option><option value="4">04</option><option value="5">05</option><option value="6">06</option><option value="7">07</option><option value="8">08</option><option value="9">09</option><option value="10">10</option><option value="11">11</option><option value="12">12</option><option value="13">13</option><option value="14">14</option><option value="15">15</option><option value="16">16</option><option value="17">17</option><option value="18">18</option><option value="19">19</option><option value="20">20</option><option value="21">21</option><option value="22">22</option><option value="23">23</option><option value="24">24</option><option value="25">25</option><option value="26">26</option><option value="27">27</option><option value="28">28</option><option value="29">29</option><option value="30">30</option><option value="31">31</option>
</select> 
<select class="month_gr" id="month_gr">
<option value="1">января</option><option value="2">февраля</option><option value="3">марта</option><option value="4">апреля</option><option value="5">мая</option><option value="6">июня</option><option value="7">июля</option><option value="8">августа</option><option value="9">сентября</option><option value="10">октября</option><option value="11">ноября</option><option value="12">декабря</option>
</select> 
<input class="year_gr" id="year_gr" type="number" size="4" name="year" min="0" max="2400" step="1" value=""> <i>г</i>. 
<select class="era_gr" id="era_gr"> 
<option value="-">до н. э.</option> <option value="">н. э.</option>
</select><br/>
по григорианскому календарю<br/>(<i>новый стиль</i>)
</div>
<div class="date">
Сегодня:<br/>
<div class="day-ulian"><select class="day_ul" id="day_ul">
</select>
<span class="day_week"></span></div><br>
<select class="date_ul" id="date_ul">
<option value="1">01</option><option value="2">02</option><option value="3">03</option><option value="4">04</option><option value="5">05</option><option value="6">06</option><option value="7">07</option><option value="8">08</option><option value="9">09</option><option value="10">10</option><option value="11">11</option><option value="12">12</option><option value="13">13</option><option value="14">14</option><option value="15">15</option><option value="16">16</option><option value="17">17</option><option value="18">18</option><option value="19">19</option><option value="20">20</option><option value="21">21</option><option value="22">22</option><option value="23">23</option><option value="24">24</option><option value="25">25</option><option value="26">26</option><option value="27">27</option><option value="28">28</option><option value="29">29</option><option value="30">30</option><option value="31">31</option>
</select> 
<select class="month_ul" id="month_ul">
<option value="1">января</option><option value="2">февраля</option><option value="3">марта</option><option value="4">апреля</option><option value="5">мая</option><option value="6">июня</option><option value="7">июля</option><option value="8">августа</option><option value="9">сентября</option><option value="10">октября</option><option value="11">ноября</option><option value="12">декабря</option>
</select> 
<input class="year_ul" id="year_ul" type="number" size="4" name="year" min="0" max="2400" step="1" value=""> <i>г</i>. 
<select class="era_ul" id="era_ul"> 
<option value="-">до н. э.</option> <option value="">н. э.</option>
</select><br/>
по юлианскому календарю<br/>(<i>старый стиль</i>)
</div>
<div>
Выберите нужную вам дату и нажмите на кнопку „Смотреть“...<br/> 
<button type="button">Смотреть</button><br/> 
При нажатии на кнопку „Сбросить“ покажет сегодняшнюю дату...<br/>
<button type=" reset">Сбросить</button>
</div>
<table align="center" bordercolor="#b8b8b8" border="1" width="100%" cellspacing="3" cellpadding="10">
<tr><td>Разница (дней)</td><td>Период (по пролептическому григорианскому календарю)</td></tr>
<tr><td>+2</td><td>27.02.101 г. до н. э. — 27.02.100 г.</td></tr>
<tr><td>+1</td><td>28.02.100 г.— 28.02.200 г.</td></tr>
<tr><td>0</td><td>1.03.200 г.— 1.03.300 г.</td></tr>
<tr><td>-1</td><td>2.03.300 г.— 2.03.500 г.</td></tr>
<tr><td>-2</td><td>3.03.500 г.— 3.03.600 г.</td></tr>
<tr><td>-3</td><td>4.03.600 г.— 4.03.700 г.</td></tr>
<tr><td>-4</td><td>5.03.700 г.— 5.03.900 г.</td></tr>
<tr><td>-5</td><td>6.03.900 г.— 6.03.1000 г.</td></tr>
<tr><td>-6</td><td>7.03.1000 г.— 7.03.1100 г.</td></tr>
<tr><td>-7</td><td>8.03.1100 г.— 8.03.1300 г.</td></tr>
<tr><td>-8</td><td>9.03.1300 г.— 9.03.1400 г.</td></tr>
<tr><td>-9</td><td>10.03.1400 г.— 10.03.1500 г.</td></tr>
<tr><td>-10</td><td>11.03.1500 г.— 14.10.1582 г.</td></tr>
<tr><td>Разница (дней)</td><td>Период (по григорианскому календарю)</td></tr>
<tr><td>-10</td><td>15.10.1582 г. — 11.03.1700 г.</td></tr>
<tr><td>-11</td><td>12.03.1700 г.— 12.03.1800 г.</td></tr>
<tr><td>-12</td>< <td>13.03.1800 г.— 13.03.1900 г.</td></tr>
<tr><td>-13</td><td>14.03.1900 г.— 14.03.2100 г.</td></tr>
<tr><td>-14</td><td>15.03.2100 г.— 15.03.2200 г.</td></tr>
<tr><td>-15</td><td>16.03.2200 г.— 16.03.2300 г.</td></tr>
</table>
</body></html>

Последний раз редактировалось Besprizornik, 11.04.2019 в 14:50.
Ответить с цитированием
  #13 (permalink)  
Старый 10.04.2019, 19:58
Кандидат Javascript-наук
Отправить личное сообщение для Besprizornik Посмотреть профиль Найти все сообщения от Besprizornik
 
Регистрация: 24.02.2019
Сообщений: 109

Rise,
а 1.01.45г до н. э. это new Date(-45,0,1) ?
Ответить с цитированием
  #14 (permalink)  
Старый 10.04.2019, 21:28
Профессор
Отправить личное сообщение для Блондинка Посмотреть профиль Найти все сообщения от Блондинка
 
Регистрация: 24.02.2019
Сообщений: 480

Besprizornik, смотри тут
Ответить с цитированием
  #15 (permalink)  
Старый 11.04.2019, 14:47
Профессор
Отправить личное сообщение для Rise Посмотреть профиль Найти все сообщения от Rise
 
Регистрация: 07.11.2013
Сообщений: 4,171

Сообщение от Besprizornik
а 1.01.45г до н. э. это new Date(-45,0,1) ?
Да, только это будет пролептическая григорианская дата, Date работает только в этой системе. И нумерация года будет астрономическая.

Последний раз редактировалось Rise, 11.04.2019 в 14:49.
Ответить с цитированием
  #16 (permalink)  
Старый 11.04.2019, 15:00
Кандидат Javascript-наук
Отправить личное сообщение для Besprizornik Посмотреть профиль Найти все сообщения от Besprizornik
 
Регистрация: 24.02.2019
Сообщений: 109

как правильно присвоить атрибут "selected" нужной опции в списке с выбором эры? и почему сейчас в исправленном коде (12ый пост) выводится не сегодняшняя дата?
Ответить с цитированием
  #17 (permalink)  
Старый 11.04.2019, 15:18
Кандидат Javascript-наук
Отправить личное сообщение для Besprizornik Посмотреть профиль Найти все сообщения от Besprizornik
 
Регистрация: 24.02.2019
Сообщений: 109

Сообщение от Rise Посмотреть сообщение
И нумерация года будет астрономическая.
а можно подробнее с этого места? что это за зверь такой "астрономическая нумерация года"?
Ответить с цитированием
  #18 (permalink)  
Старый 11.04.2019, 16:22
Профессор
Отправить личное сообщение для Rise Посмотреть профиль Найти все сообщения от Rise
 
Регистрация: 07.11.2013
Сообщений: 4,171

Gregorian & Julian converter via JDN (Julian Day Number)
Как я понял из английской википедии (в русской формулы кривые!) актуальны две системы:

1. Историческая/традиционная нумерация года (нет года 0):
- религиозная, суффикс BC (Before Christ) и префикс AD (Anno Domini), пример 2 BC, 1 BC, AD 1, AD 2.
- нерелигиозная, суффикс BCE (Before Common Era) и суффикс CE (Common Era), пример 2 BCE, 1 BCE, 1 CE, 2 CE.
По сути это аналоги для наших "до Р. Х." (Рождества Христова), "от Р. Х.", "до н. э.", "н. э.".

2. Астрономическая нумерация года (есть год 0):
Выглядит как обычная целочисленная последовательность, префикс - и префикс + (не обязательно), пример -1, 0, 1, 2.

Соответствие между ними такое:
2 BC это -1, 1 BC это 0, AD 1 это 1, AD 2 это 2. Т.е. формула для BC/BCE такая 1 - n, обратно -(n - 1), для AD/CE не изменяется.

Обычно для разных вычислений используется астрономическая. Перевести год из и в историческую можно до и после этих вычислений соответственно.

Перевод дат в Григорианский и Юлианский календарь через номер Юлианского дня.
<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <title>Gregorian & Julian converter via JDN</title>
</head>
<body>
<small>
* The algorithm is valid for all (possibly proleptic) Gregorian dates ≥ 24.11.4714 BCE and Julian dates ≥ 01.01.4713 BCE.
<a href="https://en.wikipedia.org/wiki/Julian_day" target="_blank">References</a><br><br>
</small>
<form name="converter">
    <select name="wDay"></select>
    <label>Gn:</label>
    <select name="gDay"></select>
    <select name="gMonth"></select>
    <input type="number" name="gYear" min="-4713" style="width:8ch">
    <select name="gEra"></select>
    <input type="button" name="gCalc" value="to Jn">
    <label>Jn:</label>
    <select name="jDay"></select>
    <select name="jMonth"></select>
    <input type="number" name="jYear" min="-4712" style="width:8ch">
    <select name="jEra"></select>
    <input type="button" name="jCalc" value="to Gn">
    <br><br>
    <button type="button" class="express" value="g_n_o_w_ce">Now</button>
    <button type="button" class="express" value="g_15_10_1582_ce">Gn: 15.10.1582 CE</button>
    <button type="button" class="express" value="j_1_1_45_bce">Jn: 01.01.45 BCE</button>
    <button type="button" class="express" value="j_1_1_4713_bce">Jn: 01.01.4713 BCE</button>
    <button type="button" class="express" value="j_1_1_3268_ce">Jn: 01.01.3268 CE</button>
    <button type="button" class="express" value="j_1_1_1_ce">Jn: 01.01.1 CE</button>
    <!-- Express-button format C_D_M_Y_E: Calendar "j"/"g", Day, Month, Year, Era "ce"/"bce" -->
</form>
<script>
document.addEventListener('DOMContentLoaded', function () {
// https://en.wikipedia.org/wiki/Julian_day#Julian_day_number_calculation
// 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 = ['Monday','Tuesday','Wednesday','Thursday','Friday','Saturday','Sunday'];
for (var o = '', i = 0; i < wdays.length; i++) o += '<option value="' + (i + 1) + '">' + wdays[i] + '</option>';
C.wDay.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 = ['January','February','March','April','May','June','July','August','September','October','November','December'];
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 = ['CE','BCE'], _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.wDay.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.wDay.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' or '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('_'));
}
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');
}
});
</script>
</body>
</html>

* Экспресс-кнопки можно удалить или добавить, код не поломается.

Последний раз редактировалось Rise, 11.04.2019 в 20:19. Причина: Строки 71 и 78 удалены плюсы у +C.gEra.value и +C.jEra.value
Ответить с цитированием
  #19 (permalink)  
Старый 11.04.2019, 18:06
Профессор
Отправить личное сообщение для Rise Посмотреть профиль Найти все сообщения от Rise
 
Регистрация: 07.11.2013
Сообщений: 4,171

Ааааа, уже плагин появился. Строка 100 на:
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'); }

И можно будет такие ссылочки делать:
converter.html?j=1_2_3_bce, converter.html?j=1_2_3_ce, converter.html?g=1_2_3_bce, converter.html?g=1_2_3_ce.
Ответить с цитированием
  #20 (permalink)  
Старый 12.04.2019, 21:54
Кандидат Javascript-наук
Отправить личное сообщение для Besprizornik Посмотреть профиль Найти все сообщения от Besprizornik
 
Регистрация: 24.02.2019
Сообщений: 109

Rise,
попробовал перевести скрипт на русский язык, и подогнать под себя, правда получается не очень, при попытке посмотреть 01.01.45 г. до н. э. получается н. э. и вопрос из названия темы так и остался открытым, как вывести дважды день недели текстом
<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <title>Конвертировать дату из григорианского календаря в юлианский и обратно.</title>
<style>
body, div, span, select, input, button { font: 16px serif; }
div { padding : 5px; margin: 0 5px 5px 5px; border: 1px solid #999; }
.position { display: inline-block; padding: 0; margin: 0 0 5px 0; position: relative; border: none; }
.wDay { width: 136px; }
.weekday { display: inline-block; position: relative; right: 132px; top : 1px; }
.date { white-spage: nowrap; padding: 0; margin: 0 0 5px 0; border: none; }

</style>
</head>
<body>
<form name="converter">
    <div>
    <span>Сегодня:</span><br>
    <div class="position">
   <select name="wDay" class="wDay"></select>
    <span class="weekday"></span>
    </div>
    <div class="date">
    <select name="gDay"></select>
    <select name="gMonth"></select>
    <input type="number" name="gYear" size="5" min="-4713">
    <i>г.</i>
    <select name="gEra"></select></div>
по григорианскому календарю<br>(<i>новый стиль</i>).<br>
    <input type="button" name="gCalc" value="Смотреть"> 
    <button type="button" class="express" value="g_n_o_w_ce">Сбросить</button>
    </div>
    <div>
    <span>Сегодня:</span><br>
    <div class="position">
   <select name="wDay" class="wDay"></select>
    <span class="weekday"></span>
    </div>
    <div class="date">
    <select name="jDay"></select>
    <select name="jMonth"></select>
    <input type="number" name="jYear" size="5" min="-4712">
    <i>г.</i>
    <select name="jEra"></select></div>
по юлианскому календарю<br>(<i>старый стиль</i>).<br>
    <input type="button" name="jCalc" value="Смотреть"> 
    <button type="button" class="express" value="g_n_o_w_ce">Сбросить</button>
    </div>
    <div>
    Впервые григорианский календарь был введён папой римским Григорием XIII в католических странах  с 5 октября 1582 года взамен прежнего юлианского: следующим днём после четверга 4 октября стала <button type="button" class="express" value="g_15_10_1582_ce">пятница 15 октября 1582 г. н. э.</button>. Григорианский календарь используется в большинстве государств и стран мира. В литературе также применяется название — Новый стиль.
      </div>
      <div>
    Пролептический григорианский календарь (предваряющий григорианский календарь, от др.-греч. πρόληψις «предвосхищение») — календарь, расширяющий григорианский календарь на период до его введения 15 октября 1582 года.
      </div>
      <div>
	    Юлиа́нский  календа́рь — календарь, разработанный группой александрийских астрономов во главе с Созигеном. Календарь назван в честь Юлия Цезаря, по указу которого был введен в Римской империи с <button type="button" class="express" value="j_1_1_45_bce">1 января 45 г. до н. э.</button> Год по юлианскому календарю начинается 1 января, так как именно в этот день с 153 года до н. э. избранные комициями консулы вступали в должность. Юлианский календарь заменил старый римский календарь и основывался на астрономической культуре эллинистического Египта.
</div>
</form>
<script>
document.addEventListener('DOMContentLoaded', function () {
// https://en.wikipedia.org/wiki/Julian_day#Julian_day_number_calculation
// 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.wDay.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 = ['н. э.','до н. э.'];
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.wDay.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.wDay.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' or '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('_'));
}
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');
}
});
</script>
for (var o = '', i = 0; i < wdays.length; i++) o += '<option value="' + (i + 1) + '">' + wdays[i] + '</option>';
C.wDay.innerHTML = o;
for (var o = '', i = 1; i <= 31; i++) o += '<option value="' + i  + '">' + i + '</option>';
C.gDay.innerHTML = C.jDay.innerHTML = o;
</body>
</html>
Ответить с цитированием
Ответ



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

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


Похожие темы
Тема Автор Раздел Ответов Последнее сообщение
Вывести на печать DIV как его видно в браузере (с учетом фона с стилей) unomomento Элементы интерфейса 5 27.12.2013 22:43
Как приплюсовать 3 inputa и вывести, сообщение. ainur777 Элементы интерфейса 2 10.11.2013 13:33
Как вывести значение выбранного селекта в блок? And5 Events/DOM/Window 23 11.09.2013 17:32
Подскажите, пжлст, как вывести в тот же документ результат ф-ции? LexXxeL Элементы интерфейса 4 13.05.2009 12:26
Как вывести на экран значение функции SELECT MAX(id) Владдд Серверные языки и технологии 3 25.01.2009 15:07