я бы написал "закомментировать"
ES6 классы реализованы прототипами, технически между ними нет разницы никакой.
const a = new MyClass()
и так const a = MyClass()
MyClass
на прототипах, с которым можно было бы писать так class MyExtendClass extends MyClass {...}
, ведь именно в этом контексте было сказано что Date
классом не является. const server_date = new ServerDate();
.const methodts = ["getDate", "getDay", "getFullYear", "getHours", "getMilliseconds", "getMinutes", "getMonth", "getSeconds", "getTime", "getTimezoneOffset", "getUTCDate", "getUTCDay", "getUTCFullYear", "getUTCHours", "getUTCMilliseconds", "getUTCMinutes", "getUTCMonth", "getUTCSeconds", "getYear", "setDate", "setFullYear", "setHours", "setMilliseconds", "setMinutes", "setMonth", "setSeconds", "setTime", "setUTCDate", "setUTCFullYear", "setUTCHours", "setUTCMilliseconds", "setUTCMinutes", "setUTCMonth", "setUTCSeconds", "setYear", "toDateString", "toGMTString", "toISOString", "toJSON", "toLocaleDateString", "toLocaleString", "toLocaleTimeString", "toSource", "toString", "toTimeString", "toUTCString", "valueOf"];
function ServerDate() {
let server_time_offset = 0;
const date = new Date()
methodts.forEach(method => {
this[method] = (...args) => {
date.setTime(Date.now() - server_time_offset);
return date[method](...args);
}
});
// !!!!! заремарим пока эту часть
// fetch("url роутера на сервере отдающего время в миллисекундах")
// .then((response) => {
// return response.json();
// })
// .then((data) => {
// server_time_offset = Date.now() - data.time;
// })
// а для эмуляции задержки получения даты от сервера сделаем это
setTimeout(() => {
server_time_offset = 3000; // 3 секунды
}, 1000)
}
const server_date = new ServerDate();
// сразу после инициализации в date будет время клиента
console.log(server_date.getTime());
// но когда прийдут данные с сервера, то время в date измениться
setInterval(() => {
console.log(server_date.getTime());
}, 1000)
внезапно оказывается, что можно создавать копии объекта new Date() возвращающие время с твоей поправкой
date.setTime(date.getTime() - server_time_offset); server_date = date;
const date = new Date()
ведет себя не точно так же???
А по поводу слова заремарить, то я не вижу причин, ограничивающих меня делать такую производную от слова ремарка, особенно учитывая его смысловую схожесть со словом комментарий
По факту, то что было заремарено/закомментировано (кусок кода) по своей смысловой нагрузке не является ни ремаркой ни комментарием