^
- это операция XOR. XOR вернёт единицу в том случае, если один из операндов (битов) 1 а другой 0. Таким образом, к примеру, 3 ^ 5
вернет 6 потому, что 0b011 ^ 0b101
(для простоты, биты будем считать слева направо):0 ^ 1 = 1
.1 ^ 0 = 1
.1 ^ 1 = 0
.0b110 = 6
.undefined ^ N
или 0 ^ N
, что вернёт нам само число. const start = 11 * 60 * 60;
const end = 18 * 60 * 60;
const step = 30 * 60;
const count = Math.floor((end - start) / step);
const result: string[] = [];
const date = new Date();
date.setHours(0);
date.setMinutes(0);
date.setSeconds(0);
date.setMilliseconds(0);
const format = (date: Date) => date.toLocaleTimeString('ru-RU', { hour: '2-digit', minute: '2-digit' });
for (let index = 0; index < count; index++) {
const from = new Date(date.getTime() + (start + step * index) * 1000);
const to = new Date(date.getTime() + (start + step * (index + 1)) * 1000);
result.push(`${format(from)} - ${format(to)}`);
}
console.log(result);
/* [ '11:00 - 11:30', '11:30 - 12:00', '12:00 - 12:30', '12:30 - 13:00', '13:00 - 13:30',
'13:30 - 14:00', '14:00 - 14:30', '14:30 - 15:00', '15:00 - 15:30', '15:30 - 16:00',
'16:00 - 16:30', '16:30 - 17:00', '17:00 - 17:30', '17:30 - 18:00' ] */
const inputOutput = document.getElementById('usd');
const value = (input.value * 73.84).toFixed(5) + ' $';
inputResult.value = value;
inputOutput.textContent = value;
const resultContainer = document.querySelector('.result');
if (resultContainer.classList.contains('win')) {
// ...
} else if (resultContainer.classList.contains('lose')) {
// ...
}
then
, catch
и finally
интерпретатор не будет ждать их выполнения и пойдет дальше. В итоге после "обхода" кода есть два "места", в которые вернется результат обещания. В первом promise
, во время выполнения then
мы не знаем, сколько времени потребуется для его выполнения, поэтому интерпретатор идет дальше, к следующему обещанию (в данном случае - "привязке"). Если хотите сделать так, чтобы обещания выполнялись именно в том порядке, который описан в коде, то надо писать как-то так:(async () => {
const promise = new Promise((resolve, reject) => {
resolve(console.log('start'));
});
await promise
.then(x => console.log('x'))
.then(y => console.log('y'));
await promise.then(z => console.log('z'));
})();
const start = async () => {
const promise = new Promise((resolve, reject) => {
resolve(console.log('start'));
});
await promise
.then(x => console.log('x'))
.then(y => console.log('y'));
await promise.then(z => console.log('z'));
};
start();
const promise = new Promise((resolve, reject) => {
resolve(console.log('start'));
});
await promise
.then(x => console.log('x'))
.then(y => console.log('y'));
await promise.then(z => console.log('z'));
Ctrl + Shit + P > Configure User Snippet > SCSS
scss.json
. И scope
уберите.