
- Главная
- Каталог
- Интернет технологии
- JavaScript Ready | Frontend
JavaScript Ready | Frontend
Авторский канал по разработке на JavaScript.
Статистика канала
const arr = ["a", "b", "c", "d"];
const last = arr[arr.length - 1];
const prev = arr[arr.length - 2];
console.log(last); // "d"
console.log(prev); // "c"{}
При сложных выражениях или частых обращениях к последним элементам такой код становится менее читаемым.
Современный метод at() позволяет обращаться к элементам массива с конца через отрицательные индексы:
const arr = ["a", "b", "c", "d"];
arr.at(-1); // "d"
arr.at(-2); // "c"{}
Метод также поддерживает обычные положительные индексы:
arr.at(0); // "a"
arr.at(2); // "c"{}
Если индекс выходит за пределы массива, метод возвращает undefined:
arr.at(100); // undefined
arr.at(-100); // undefined{}
Один из практических сценариев — работа со стеком, когда нужно быстро посмотреть верхний элемент:
function peek(stack) {
return stack.at(-1);
}{}
Метод работает не только с массивами, но и со строками:
"hello".at(-1); // "o"{}
В отличие от charAt(), метод at() поддерживает отрицательные индексы.
Он также доступен для TypedArray:
const bytes = new Uint8Array([10, 20, 30]);
bytes.at(-1); // 30{}
matchMedia() — Web API, позволяющий проверять и отслеживать media queries напрямую из JavaScript. Это помогает синхронизировать поведение JS-кода с CSS-адаптивностью.
Функция возвращает объект MediaQueryList, содержащий результат проверки media query.
Базовое использование:
const media = window.matchMedia('(max-width: 768px)');
console.log(media.matches);{}
matches — boolean, показывающий соответствует ли текущий viewport заданному media query.
Пример 1 — проверка условия:
if (window.matchMedia('(prefers-color-scheme: dark)').matches) {
document.body.classList.add('dark-theme');
}{}
Так можно адаптировать поведение интерфейса под системные настройки пользователя.
Пример 2 — отслеживание изменения media query:
const media = window.matchMedia('(max-width: 768px)');
media.addEventListener('change', e => {
console.log('mobile:', e.matches);
});{}
Событие change срабатывает при изменении состояния media query.
Это позволяет реагировать на изменение состояния media query без использования window.resize.
Пример 3 — адаптация логики интерфейса:
const media = window.matchMedia('(max-width: 600px)');
function updateLayout(mql) {
if (mql.matches) {
enableMobileLayout();
} else {
enableDesktopLayout();
}
}
updateLayout(media);
media.addEventListener('change', updateLayout);{}
Обработчик сначала вызывается вручную для установки начального состояния, затем автоматически при изменении media query.
Пример 4 — учет пользовательских настроек доступности:
const motion = window.matchMedia('(prefers-reduced-motion: reduce)');
if (motion.matches) {
disableAnimations();
}{}
Media queries позволяют учитывать пользовательские настройки доступности.
Пример 5 — отслеживание ориентации экрана:
const orientation = window.matchMedia('(orientation: portrait)');
orientation.addEventListener('change', e => {
console.log('portrait:', e.matches);
});{}
matchMedia используется для: адаптивной логики интерфейса, синхронизации JavaScript и CSS media queries, учета пользовательских настроек доступности и оптимизации поведения UI на разных устройствах.
matchMedia — удобный способ проверять и отслеживать media queries напрямую из JavaScript.
Шпаргалка по базовым операциям с регулярными выражениями. Показано, как проверять наличие совпадений, извлекать найденные фрагменты и группы захвата, получать все совпадения в строке, а также выполнять поиск, замену и разделение строк по шаблону. Также кратко разобраны различия в поведении методов и влияние флагов регулярных выражений.
Loading … ██████████████] 99%Роскомнадзору дали карт-бланш на блокировки, а «белые списки» сайтов тестируют уже в десятках регионов. И гайки будут закручиваться только сильнее. Чтобы в одночасье не лишиться доступа к свободному Интернету, просто сохрани Only Hack. Тут профессиональный хакер делится фишками, с которыми доступ к глобальной сети у тебя будет даже в случае ядерного апокалипсиса. Не жди момента «Х». Перестрахуйся подпиской.
Оставляю ссылочку: GitHub📱
reduce:
const byId = users.reduce((acc, u) => {
(acc[u.id] ??= []).push(u);
return acc;
}, {});{}
Но в современном JS есть нативный способ группировки — Object.groupBy():
Object.groupBy(iterable, callback){}
Метод принимает итерируемую коллекцию и функцию, которая возвращает ключ группы:
const byId = Object.groupBy(users, u => u.id);{}
Результат — объект, где ключи это группы, а значения — массивы элементов:
{
"1": [{ id: 1, name: 'Jane' }],
"2": [{ id: 2, name: 'John' }]
}{}
Ключи в Object.groupBy() становятся свойствами объекта.
Если нужны ключи любого типа без преобразования — можно использовать Map.groupBy():
const grouped = Map.groupBy(users, u => u.id);{}
Отзывы канала
Каталог Телеграм-каналов для нативных размещений
JavaScript Ready | Frontend — это Telegam канал в категории «Интернет технологии», который предлагает эффективные форматы для размещения рекламных постов в Телеграмме. Количество подписчиков канала в 8.1K и качественный контент помогают брендам привлекать внимание аудитории и увеличивать охват. Рейтинг канала составляет 12.2, количество отзывов – 0, со средней оценкой 0.0.
Вы можете запустить рекламную кампанию через сервис Telega.in, выбрав удобный формат размещения. Платформа обеспечивает прозрачные условия сотрудничества и предоставляет детальную аналитику. Стоимость размещения составляет 1818.18 ₽, а за 7 выполненных заявок канал зарекомендовал себя как надежный партнер для рекламы в TG. Размещайте интеграции уже сегодня и привлекайте новых клиентов вместе с Telega.in!
Вы снова сможете добавить каналы в корзину из каталога
Комментарий