Web Overflow 🇺🇦
4.42K subscribers
380 photos
40 videos
3 files
518 links
Затишний блог про веб-розробку і не тільки 💛

Чат: @web_overflow_chat
Співпраця: @web_overflow_support
Автори: @lluchkaa & @anastasiia_tarasenko
加入频道
👍53🔥1
Що виведе консоль?
Anonymous Quiz
41%
0
20%
~0
22%
-1
16%
1
👍7🤨42🔥1
#todo написати функцію на будь-якій мові програмування, яка приймає масив чисел у проміжку [0, 100]. Функція має повернути обʼєкт/map/словник з погрупованими числами за кількістю десятків та сформувати ключі у вигляді "0-9", "10-19", "20-29" і т.д.
👍53🔥1
Як додати перевірку свого коду на GitHub Actions? 🌩️

Припустимо, що ваш застосунок написаний на JavaScript. Якщо ж ви використовуєте іншу мову, можете теж використовувати цей підхід, потрібно буде лише замінити скрипт перевірки. Отож, уявіть себе девопсом yaml-розробником і почнімо.

Власне, перед початком налаштовування GitHub Action ми зазвичай робимо ще одну річ - додаємо власний скрипт в package.json, який трохи спростить використання і запуск команди. Найчастіше ми додаємо там перевірку форматування через prettier та статичний аналіз з допомогою eslint та tsc. Виглядає це приблизно отак:

"scripts": {
"check": "prettier --check . && eslint . && tsc --noEmit"
}


Для початку в корені свого проєкту потрібно створити директорію .github, всередині якої ще одну з назвою workflows. Тут ми і будемо розміщувати свій файл конфігурації. Створимо цей файл і дамо йому назву check.yml.

Якщо ви не знайомі з YAML, це як JSON на Python. Головне слідкуйте за відступами.

Почнемо з імені, додайте у файл:

name: Run web check


Тепер треба прописати, коли ж запускати цей екшн. Дозволимо запускати його ручками та будемо автоматично запускати його при будь-якому пуші.

on:
workflow_dispatch: # вручну на GitHub
push: # при push в репозиторій


Почнімо ж нарешті описувати кроки перевірок. Створимо job з іменем check. Запускати це все ми будемо на останній ubuntu, а першим кроком додамо клонування вашого репозиторію.

jobs:
check:
runs-on: ubuntu-latest

steps:
- name: Checkout repository
uses: actions/checkout@v4


Отож, на цій машині вже є наш репозиторій. А на ubuntu одразу встановлений Node.js? Не знаємо, тому краще встановити його. На всяк випадок вкажемо версію Node.js. А ще, GitHub сам вміє кешувати модулі Node.js, тому скажемо йому робити це також.

- name: Setup Node.js 20
uses: actions/setup-node@v4
with:
node-version: 20
cache: 'npm'


Ну тепер Node.js точно є, але немає node_modules. Ну це вже дуже просто, всі ми знаємо потрібну команду.

- name: Install dependencies
run: npm install


Нарешті, все готово, залишилось тільки запустити нашу перевірку. Оскільки ми вже підготували потрібний скрипт, просто запустимо його.

- name: Run check
run: npm run check


Усе це разом, а також з невеличким налаштуванням pnpm, concurrency, strategy та монорепо (Node.js застосунок знаходиться не в корені проєкту), можна знайти за посиланням нижче.
👉 Відкрити файл

Щоб більше почитати про GitHub Actions використовуйте посилання внизу. А від @MatiGreen чекаємо повідомлення про те, як зробити те саме на GitLab 😉
👉 Відкрити посилання

#article
👍146🔥6
Welcome!

Let's practice our English! So...

👉 What habits would you like to give up?

Have a nice #english_friday 💛
👍6🤔32🔥1
This media is not supported in your browser
VIEW IN TELEGRAM
#how_to створити Infinite Scroll Animation ♾️

Виконаний з допомогою React та SCSS!

👉 Відкрити посилання
👍8🔥51👏1
Bongo Cat Buddy 🙀

Котики завжди роблять речі кращими. Одного разу кіт пробігся по клавіатурі і тепер так звуть дитину Маска 😹

Ділимося з вами розширенням Bongo Cat Buddy, яке не дозволить вам засумувати. Котик буде стукати лапкою з вами в такт. Тому баги, які ви фіксаєте, вже не виглядатимуть такими страшними і серйозними.

👉 Відкрити посилання

#tips
6👍4😁3🤯1
JavaScript ASI 🥴

Просто шматок коректного TypeScript коду:

;(variable as string).toLowerCase()


Насправді, таке ж можна знайти і в JavaScript. Для тих, кому цікава причина такого дивного форматування, додаємо посилання на коротке відео з поясненням.

👉 Дивитись відео

#shorts
👍102💩1
🤔8👍4
🤔13👍51
#todo написати функцію на будь-якій мові програмування, яка приймає голову однозвʼязного списку та повертає голову нового списку, що відповідає розвернутому оригінальному списку.

Тип вузла:

type Node<T> = {
value: T;
next?: Node<T>;
}
👍52
Tailwind CSS v2.0 💅

Вам може подобатись CSS, а може і не подобатись, може подобатись лише Bootstrap, MUI чи CSS-in-JS. Але світ такий, що найпопулярніший підхід зараз - це TailwindCSS. А якщо ви як @Yurets7777 пропускали пости про цей CSS-фреймворк, це означає, що точно потрібно наздоганяти.

На щастя, Max Alekseyev (хотіли нормально тегнути, але немає username 🥲) поділився в чаті офіційним плей-листом, де ви швидко та без води можете ознайомитись з TailwindCSS. Хоч там і друга версія, суть залишилась та сама.

👉 Відкрити посилання

#tips
👍10😁61🔥1💩1
Welcome!

Let's practice our English! So...

👉 If you had your own business, what area would it be related to?

Have a nice #english_friday 💛
👍42
This media is not supported in your browser
VIEW IN TELEGRAM
#how_to створити Confetti Button 🎉

Виконаний з допомогою React та CSS!

👉 Відкрити посилання
🎉13👍41
👍6🤔21
#todo написати функцію на будь-якій мові програмування, яка приймає натуральне число N і повертає масив чисел, що містить усі прості числа у проміжку [0, N).
👍4🤔31
pnpm 9.0 📦

Тут нещодавно pnpm релізнули нову версію. Що таке pnpm і чи варто його використовувати ми розповідали ось тут.

Тому, якщо це менеджер пакетів, який ви використовуєте, можете потроху готувати перехід.

А нижче додаємо посилання, за яким зможете знайти більше деталей цього релізу.

👉 Відкрити посилання

#tips
4👍4❤‍🔥1🔥1
Welcome!

Let's practice our English! So...

👉 What is the strangest thing you have ever eaten?

Have a nice #english_friday 💛
👍3🤔21
👍6🔥21