УлÑÑÑеннÑе ÑаÑÑ
важноÑÑÑ: 5
У Ð½Ð°Ñ ÐµÑÑÑ ÐºÐ»Ð°ÑÑ Clock. СейÑÐ°Ñ Ð¾Ð½ вÑÐ²Ð¾Ð´Ð¸Ñ Ð²ÑÐµÐ¼Ñ ÐºÐ°Ð¶Ð´ÑÑ ÑекÑндÑ
class Clock {
constructor({ template }) {
this.template = template;
}
render() {
let date = new Date();
let hours = date.getHours();
if (hours < 10) hours = '0' + hours;
let mins = date.getMinutes();
if (mins < 10) mins = '0' + mins;
let secs = date.getSeconds();
if (secs < 10) secs = '0' + secs;
let output = this.template
.replace('h', hours)
.replace('m', mins)
.replace('s', secs);
console.log(output);
}
stop() {
clearInterval(this.timer);
}
start() {
this.render();
this.timer = setInterval(() => this.render(), 1000);
}
}
СоздайÑе новÑй клаÑÑ ExtendedClock, коÑоÑÑй бÑÐ´ÐµÑ Ð½Ð°ÑледоваÑÑÑÑ Ð¾Ñ Clock и добавÑÑе паÑамеÑÑ precision â колиÑеÑÑво миллиÑекÑнд Ð¼ÐµÐ¶Ð´Ñ Â«Ñиками». УÑÑановиÑе знаÑение в 1000 (1 ÑекÑнда) по ÑмолÑаниÑ.
- СоÑ
ÑаниÑе Ð²Ð°Ñ ÐºÐ¾Ð´ в Ñайл
extended-clock.js - Ðе изменÑйÑе клаÑÑ
clock.js. РаÑÑиÑÑÑе его.
class ExtendedClock extends Clock {
constructor(options) {
super(options);
let { precision = 1000 } = options;
this.precision = precision;
}
start() {
this.render();
this.timer = setInterval(() => this.render(), this.precision);
}
};