開発環境
- macOS Sierra - Apple (OS)
- Emacs (Text Editor)
- JavaScript (プログラミング言語)
- Node.js, Safari(JavaScript エンジン)
- Learning JavaScript [邦訳](参考書籍)
Think Perl 6: How to Think Like a Computer Scientist (Laurent Rosenfeld(著)、Allen B. Downey(著)、Oreilly & Associates Inc)の art 2(Moving Forward)、Chapter 13(Regexes and Grammars)の Named Rules (a.k.a. Subrules)、Exercise 13-1: Getting the Feburary Dates Right.を JavaScript で取り組んでみる。
Exercise 13-1: Getting the Feburary Dates Right.
コード(Emacs)
HTML5
<pre id="output0"></pre> <input id="date0" type="date" value="2016-12-31"> <button id="run0">run</button> <button id="clear0">clear</button> <script src="sample1.js"></script>
JavaScript
let btn0 = document.querySelector('#run0'),
btn1 = document.querySelector('#clear0'),
pre0 = document.querySelector('#output0'),
input_date = document.querySelector('#date0'),
p = (x) => pre0.textContent += x + '\n',
range = (start, end, step=1) => {
let result = [];
for (let i = start; i < end; i += 1) {
result.push(i);
}
return result;
};
let output = () => {
let date = input_date.value,
dates = ['Chrimstmas : 2016-12-25.', '2016-02-28', '2016-02-30', date];
dates.forEach((date) => {
p(date);
let m1 = date.match(/(\d{4})[-/](0[469]|11)[-/](0[1-9]|[12][0-9]|30)/),
m2 = date.match(
/(\d{4})[-/](0[13578]|1[02])[-/](0[1-9]|[12][0-9]|3[01])/),
m3 = date.match(/(\d{4})[-/](02)[-/](0[1-9]|[12][0-8])/),
m = m1 || m2 || m3;
if (m) {
p(m[0]);
p(`Day = ${m[1]}`);
p(`Month = ${m[2]}`);
p(`Year = ${m[3]}`);
}
p('');
});
};
let clear = () => pre0.textContent = '';
input_date.onchange = output;
btn0.onclick = output;
btn1.onclick = clear;
output();
0 コメント:
コメントを投稿