en
Feedback
JavaScript заметки

JavaScript заметки

Open in Telegram

Регулярные заметки по практическому JavaScript. Обучащию посты позволят прокачать навыки во Frontend-разработке. Можно почитать пока компилируется проект :) Сотрудничество: @noname_media Канал на бирже: telega.in/channels/notesjs/card?r=Wj7h1mbl

Show more
7 737
Subscribers
-324 hours
-77 days
-5430 days
Posts Archive
Proxy: Значение по умолчанию с ловушкой «get» Чаще всего используются ловушки на чтение/запись свойств. Чтобы перехватить опе
Proxy: Значение по умолчанию с ловушкой «get» Чаще всего используются ловушки на чтение/запись свойств. Чтобы перехватить операцию чтения, handler должен иметь метод get(target, property, receiver). Он срабатывает при попытке прочитать свойство объекта, с аргументами: - target – это оригинальный объект, который передавался первым аргументом в конструктор new Proxy, - property – имя свойства, - receiver – если свойство объекта является геттером, то receiver – это объект, который будет использован как this при его вызове. Обычно это сам объект прокси (или наследующий от него объект). Прямо сейчас нам не понадобится этот аргумент, подробнее разберём его позже. Давайте применим ловушку get, чтобы реализовать «значения по умолчанию» для свойств объекта. Например, сделаем числовой массив, так чтобы при чтении из него несуществующего элемента возвращался 0. #разное #proxy #ловушки

Вы тоже слышали, что стать айтишником - сложно? Знайте, это ложь. Выучить 2-3 языка, устроиться на работу и получать от $900
Вы тоже слышали, что стать айтишником - сложно? Знайте, это ложь. Выучить 2-3 языка, устроиться на работу и получать от $900 можно за полтора месяца. Главное ─ чтобы всё объяснили на примерах и показали, что к чему. За этим идите в канал «Точка входа в IT». Здесь есть короткие уроки, шпаргалки по коду и наглядные примеры, что нужно делать, чтобы всё работало. Идеально для тех, кто пока чайник, но хочет стартонуть без дорогих курсов и прочей фигни. Заходите: @it_tochka

Proxy: ловушки Proxy – это особый объект, у него нет собственных свойств. С пустым handler он просто перенаправляет все опера
Proxy: ловушки Proxy – это особый объект, у него нет собственных свойств. С пустым handler он просто перенаправляет все операции на target. Чтобы активировать другие его возможности, добавим ловушки. Для большинства действий с объектами в спецификации JavaScript есть так называемый «внутренний метод», который на самом низком уровне описывает, как его выполнять. Например, [[Get]] – внутренний метод для чтения свойства, [[Set]] – для записи свойства, и так далее. Эти методы используются только в спецификации, мы не можем обратиться напрямую к ним по имени. Ловушки как раз перехватывают вызовы этих внутренних методов. Полный список методов, которые можно перехватывать, перечислен в спецификации Proxy, а также в таблице ниже. Для каждого внутреннего метода в этой таблице указана ловушка, то есть имя метода, который мы можем добавить в параметр handler при создании new Proxy, чтобы перехватывать данную операцию. P.S. На картинке отображена таблица со всеми доступными ловушками. #разное #proxy #ловушки

​​Больше не нужно учить JavaScript несколько лет. Теперь всю необходимую информацию можно легко и быстро впитать по понятным картинкам. 🔸Узнать JavaScript за неделю? Не проблемаguides_js

Proxy Объект Proxy «оборачивается» вокруг другого объекта и может перехватывать (и, при желании, самостоятельно обрабатывать)
Proxy Объект Proxy «оборачивается» вокруг другого объекта и может перехватывать (и, при желании, самостоятельно обрабатывать) разные действия с ним, например чтение/запись свойств и другие. Далее мы будем называть такие объекты «прокси». Прокси используются во многих библиотеках и некоторых браузерных фреймворках. Синтаксис: let proxy = new Proxy(target, handler); - target – это объект, для которого нужно сделать прокси, может быть чем угодно, включая функции. - handler – конфигурация прокси: объект с «ловушками» («traps»): методами, которые перехватывают разные операции, например, ловушка get – для чтения свойства из target, ловушка set – для записи свойства в target и так далее. При операциях над proxy, если в handler имеется соответствующая «ловушка», то она срабатывает, и прокси имеет возможность по-своему обработать её, иначе операция будет совершена над оригинальным объектом target. #разное #proxy

Асинхронные итераторы Асинхронные итераторы похожи на обычные итераторы, но имеют некоторые синтаксические отличия. Чтобы сде
Асинхронные итераторы Асинхронные итераторы похожи на обычные итераторы, но имеют некоторые синтаксические отличия. Чтобы сделать объект итерируемым асинхронно: 1. Используется Symbol.asyncIterator вместо Symbol.iterator 2. next() должен возвращать промис. 3. Чтобы перебрать такой объект, используется цикл for await (let item of iterable). На картинке выше вы можете увидеть итерируемый объект range. #генераторы #асинхронные_итераторы

Цепочка промисов Идея состоит в том, что результат первого промиса передаётся по цепочке обработчиков .then. Поток выполнения
Цепочка промисов Идея состоит в том, что результат первого промиса передаётся по цепочке обработчиков .then. Поток выполнения такой: - Начальный промис успешно выполняется через 1 секунду (*), - Затем вызывается обработчик в .then (**). - Возвращаемое им значение передаётся дальше в следующий обработчик .then (***) - …и так далее. В итоге результат передаётся по цепочке обработчиков, и мы видим несколько alert подряд, которые выводят: 1 → 2 → 4. #промисы #цепочка_промисов

Микрозадачи Асинхронные задачи требуют правильного управления. Для этого стандарт предусматривает внутреннюю очередь PromiseJ
Микрозадачи Асинхронные задачи требуют правильного управления. Для этого стандарт предусматривает внутреннюю очередь PromiseJobs, более известную как «очередь микрозадач (microtask queue)» (термин V8). Как сказано в спецификации: - Очередь определяется как первым-пришёл-первым-ушёл (FIFO): задачи, попавшие в очередь первыми, выполняются тоже первыми. - Выполнение задачи происходит только в том случае, если ничего больше не запущено. Или, проще говоря, когда промис выполнен, его обработчики .then/catch/finally попадают в очередь. Они пока не выполняются. Движок JavaScript берёт задачу из очереди и выполняет её, когда он освободится от выполнения текущего кода. Вот почему сообщение «код выполнен» в примере выше будет показано первым. #микрозадачи #промисы

Callbacks (Колбэки) Колбэк функция - это такая функция, которая вызывается после выполнения какой-то асинхронности. В данном
Callbacks (Колбэки) Колбэк функция - это такая функция, которая вызывается после выполнения какой-то асинхронности. В данном примере описана функция динамической подгрузки скриптов с колбеком, после загрузки. Функция callback выполнится, когда скрипт будет полностью загружен на странице. Колбэки используются повсеместно, не только в JavaScript. #callback #колбэк #продвинутый

Сложно мониторить множество ресурсов чтобы быть в курсе современного фронтенда? 🤯 Канал Frontend Info сделал это за тебя: ✔️
Сложно мониторить множество ресурсов чтобы быть в курсе современного фронтенда? 🤯 Канал Frontend Info сделал это за тебя: ✔️ Цикл рендеринга браузера, аппаратное ускорение и уровни компоновщика ✔️ Почему Remix стоит вашего внимания ✔️ Запись докладов React Conf 2021 Каждый день ты будешь получать актуальные статьи, отборные туториалы, видеокурсы и многое другое для твоего развития 🚀

Промисификация Промисификация – это длинное слово для простого преобразования. Мы берём функцию, которая принимает колбэк и м
Промисификация Промисификация – это длинное слово для простого преобразования. Мы берём функцию, которая принимает колбэк и меняем её, чтобы она вместо этого возвращала промис. Такие преобразования часто необходимы в реальной жизни, так как многие функции и библиотеки основаны на колбэках, а использование промисов более удобно, поэтому есть смысл «промисифицировать» их. Например, у нас есть loadScript(src, callback) (см. левую часть картинки) Давайте промисифицируем её. Новая функция loadScriptPromise(src) будет делать то же самое, но будет принимать только src (не callback) и возвращать промис (см. правую часть картинки) #promise #продвинутый

👨🏻‍💻 no system is safe — канал с бесплатными обучающими материалами для IT специалистов. - Новости из сферы IT. - Сотни ст
👨🏻‍💻 no system is safe — канал с бесплатными обучающими материалами для IT специалистов. - Новости из сферы IT. - Сотни статей и публикаций с обучающим материалом для ИБ специалистов. - Подборки полезного материала для IT специалистов любого уровня и направления. - Хакинг и способы защиты от него.

Eval: выполнение строки кода Встроенная функция eval позволяет выполнять строку кода. Синтаксис: let result = eval(code); Стр
Eval: выполнение строки кода Встроенная функция eval позволяет выполнять строку кода. Синтаксис: let result = eval(code); Строка кода может быть большой, содержать переводы строк, объявления функций, переменные и т.п. Результатом eval будет результат выполнения последней инструкции. Использование В современной разработке на JavaScript eval используется весьма редко. Есть даже известное выражение – «eval is evil» («eval – это зло»). Причина такого отношения достаточно проста: давным-давно JavaScript был не очень развитым языком, и многие вещи можно было сделать только с помощью eval. Но та эпоха закончилась более десяти лет назад.

Недавно Илон Маск заявил, что собирается запустить в космос ещё 51 спутник высокоскоростного интернета Starlink. В сумме таки
Недавно Илон Маск заявил, что собирается запустить в космос ещё 51 спутник высокоскоростного интернета Starlink. В сумме таких спутников будет уже 1738. Только вот пока обычные люди радуются быстрому беспроводному интернету, эксперты по вопросам кибербезопасности бьют тревогу. Дело в том, что к спутникам можно легко подключить заражённые IoT-устройства: смарт-часы, умный дом и другие гаджеты, которые не имеют защиты. А уже сколько дел может натворить опытный хакер, можно только догадываться... Один из худших раскладов — масштабная DDoS-атака из различных точек мира, которую будет невозможно предотвратить. В подробностях о таком раскладе и последствиях можно прочесть в закрепе на этом канале. Там эксперты из сферы кибербезопасности делятся полезной информацией и новостями из мира IT.

Динамические импорты Инструкции экспорта и импорта, которые мы рассматривали в предыдущем посте, называются «статическими». С
Динамические импорты Инструкции экспорта и импорта, которые мы рассматривали в предыдущем посте, называются «статическими». Синтаксис у них весьма простой и строгий. Во-первых, мы не можем динамически задавать никакие из параметров import. Путь к модулю должен быть строковым примитивом и не может быть вызовом функции. Вот так работать не будет: Во-вторых, мы не можем делать импорт в зависимости от условий или в процессе выполнения. Все эти проблемы решает выражение import(module). Выражение import() Выражение import(module) загружает модуль и возвращает промис, результатом которого становится объект модуля, содержащий все его экспорты. Использовать его мы можем динамически в любом месте кода, как показано на скрине выше. #динамический_импорт #модули

​​Готов проверить насколько ты крут во фронтенде? На канале Frontend Tests & Tasks мы собираем для Вас самые интересные вопросы и  задачи по фронтенду. Если вдруг не сможешь решить задачу - не беда, мы подробно объясним её решение. Готов? Тогда поехали 👉 @frontend_tests

Экспорт и импорт С помощью ключевых слов import и export мы можем соответственно импортировать и экспортировать переменные, ф
Экспорт и импорт С помощью ключевых слов import и export мы можем соответственно импортировать и экспортировать переменные, функции, классы и другие сущности языка. На картинке показан пример экспорта и импорта простых функций из файла say.js в main.js. #export #import #модули

Решайте практические тесты из собеседований на нашем втором канале @tests_js

CSS-фича, это новый канал для верстальщика и фронтенд-разработчика. Здесь всегда можно найти что то нужное для себя! - слайде
CSS-фича, это новый канал для верстальщика и фронтенд-разработчика. Здесь всегда можно найти что то нужное для себя! - слайдеры - чекбоксы - кнопки с hover-эффектами - только годные сервисы - так же у нас найдете шпаргалки по css grid и flexbox - викторины, для изучения чего то нового - формы и т.д. Заходи на канал CSS-фичи , забирай код и внедряй себе в проект !

Наследование классов Наследование extends пришло в JS с ES6 синтаксисом. Ключевое слово extends работает, используя прототипы
Наследование классов Наследование extends пришло в JS с ES6 синтаксисом. Ключевое слово extends работает, используя прототипы. Оно устанавливает Rabbit.prototype.[[Prototype]] в Animal.prototype. Так что если метод не найден в Rabbit.prototype, JavaScript берёт его из Animal.prototype. #наследование #классы