👁‍🗨 CODORUM — пишу на JavaScript
803 subscribers
146 photos
83 videos
229 links
🟣 Канал создан с целью совместного обучения программированию на языке JavaScript 🟨

✔️ Канал подойдёт для тех кто желает:
научиться программировать на языке JavaScript
расширить свой кругозор в знаниях функций на JS

🎥 Ютуб канал: youtube.com/@codorum
Download Telegram
17 часть по разработке сайта-визитки на ReactJS уже на ютуб каналадаптация блока портфолио 👈 жми, чтобы посмотреть 🔴

В ней мы настроили отображение 4-го блока для мобильных устройств, при этом сохранив основные функции без необходимости их редактирования. Адаптировали блок в главном компоненте Main и компоненты имеющие отношение к блоку. Немного изменили идею стилизации и отображения элементов блока и компонентов для мобильных устройств 📱

Буду благодарен, если поддержите видео лайком 👍
👍2🔥1
Опубликовал 18 часть по разработке сайта-визитки на ReactJS на ютуб каналeадаптация блока отзывов 👈 жми, чтобы посмотреть 🔴

В этой части мы адаптировали 5-й блок под мобильные устройства. Прописали дополнительные классы для элементов блока моб. версии и подкорректировать шаблон отзывов, изменили концепцию контейнера с отзывами. Показал лайфхак для плашек (выделения слов в тексте) - как сделать плашки неразрывными/неуязвимыми для переносов текста 🟧

Буду благодарен, если поддержите видео лайком 👍
👍4🔥2
Рассмотрим тип объекта Date в JavaScript ⚜️

Date – это тип объекта, который позволяет создавать, представлять и взаимодействовать с датами и временем (год, месяц, день, час, минута и другие)

Существуют методы для получения и изменения даты и времени (детальнее на скрине) ⏲️

Стоит учесть, что отсчет месяцев начинается с нуля, где январь - 00, февраль - 01 и так далее 👁‍🗨

Код со скрина:
const TimeNow = new Date();

// методы для получения компонентов времени объекта TimeNow
let year = TimeNow.getFullYear();
let month = TimeNow.getMonth();
let day = TimeNow.getDate();
let hours = TimeNow.getHours();
let min = TimeNow.getMinutes();
let sec = TimeNow.getSeconds();

console.log(`Сегодня ${day}.${month + 1}, ${year} год`);


// пример метода по установке времени для объекта TimeNow (час, минута)
TimeNow.setHours(14, 30);
👍3🔥2
This media is not supported in your browser
VIEW IN TELEGRAM
У нас новый диктор! 🎙

Просим сравнить качество звука и подачу предыдущего диктора и нового диктора в следующем посте 👇
🔥3
Загрузил финальную 19 часть по разработке сайта-визитки на ReactJS на ютуб каналадаптация блока гарантий и подвала 👈 жми, чтобы посмотреть 🔴

В которой мы адаптировали 6-й и 7-й блоки для моб. устройств, чем закончили адаптацию страницы и сайт-визитку в целом. Из нового: рассмотрели новую конструкцию, подобную конструкции с долларом, применяющую разные классы, в зависимости от значений двух переменных, для кнопки, переносящей нас в начало страницы ⚛️

Буду благодарен, если поддержите видео лайком 👍
👍21🔥1
Где чаще всего используют JavaScript? 🟨

Хочу показать интересные данные, основанные на результатах исследования Developer Ecosystem Survey, которое ежегодно проводит JetBrains 📊

JavaScript остается основным инструментом для фронтенд-разработки. 86% респондентов работают с фронтендом, включающим создание веб-сайтов, веб-приложений и пользовательских интерфейсов 🖥

Хотя JavaScript менее популярен в бэкенде, его все же широко используют через платформу Node.js. Примерно 34% разработчиков используют JavaScript для бэкенд-разработки, что делает его важнейшим инструментом для создания серверных частей приложений 🟩
👍41🔥1
Недавно я опубликовал последнюю часть по разработке сайта-визитки на ReactJS (все части в плейлисте на моём ютуб каналe). Это серия роликов, где я поэтапно показываю как разрабатываю одностраничный сайт-портфолио используя NodeJS и библиотеку React ⚛️

Если вы еще не смотрели ни одной части — предлагаю посмотреть на то, что у нас получилось по итогу в ролике обзор финального результата 👈 жми, чтобы посмотреть 🔴

В рамках частей мы также рассмотрели интересные моменты html верстки 🟧, стилизации и создании некоторых CSS анимаций 🟦

Буду благодарен, если поддержите видео лайком и напишите свое мнение в комментарии под видео 💬
❤‍🔥4👍2
This media is not supported in your browser
VIEW IN TELEGRAM
Интересная идея кнопки, по нажатию на которую появляется текст на чистом html и CSS, без добавления функции на JavaScript 🟨

Всё что необходимо это прописать саму кнопку, текст в файле index.html и три стиля в файле index.css 📁

С кнопкой связан скрытый checkbox. При нажатии на кнопку ставится галочка в checkbox. Подробнее в видео 👁‍🗨

Код с видео:

// ✦ index.html
<label for="btn" class="btn">Кнопка</label>
<input type="checkbox" id="btn"></input>
<div class="text">привет</div>


// ✦ index.css
.text, input[type="checkbox"] {
opacity: 0;
margin-top: -10px;
transition: opacity 400ms, margin-top 500ms;
display: block;
}

input[type="checkbox"]:checked ~ .text {
opacity: 1;
margin-top: 10px;
}

.btn {
padding: 6px 18px;
background-color: #485dff;
color: #eceeff;
cursor: pointer;
border-radius: 8px;
}
👍4🔥2
С помощью метода indexOf можно узнать индекс элемента в массиве 🟨

Для этого прописываем название массива, далее метод и в скобках указываем элемент из массива, индекс которого хотим узнать 🔮

Но есть нюанс: все элементы массива должны быть разными. Если в массиве больше двух одинаковых элементов, то хоть и есть еще один метод lastIndexOf, который находит индекс последнего такого же элемента, не обойтись без итераций. Если в массиве, допустим, 3 одинаковых элемента (подробнее на скрине) 👁‍🗨

Код со скрина:
let arr = ["White", "Fring", "Goodman", "Pinkman"];

console.log("Индекс личности", "Fring -", arr.indexOf("Fring"));



let arr2 = ["BTC", "BTC", "BTC"];

console.log("\nИндекс первого", "BTC -", arr2.indexOf("BTC"));
console.log("Индекс последнего", "BTC -", arr2.lastIndexOf("BTC"));
🔥5
Рассмотрим тип объекта RegExp в JavaScript ⚜️

RegExp – это тип объекта, который используется для работы с регулярными выражениями, позволяющими выполнять расширенные операции со строками, такие как: поиск, замена и извлечение определенных паттернов 🔖

Объект RegExp можно создать с помощью литерала регулярного выражения или конструктора 🏗

На скрине продемонстрированы 2 метода: test и search. Но объект RegExp предоставляет и другие различные методы выполнения операций со строками, такие как: exec, match, replace и другие 👁‍🗨

Код со скрина:
const pattern1 = new RegExp('Codorum');
const pattern2 = new RegExp('JavaScript');

const text = 'Codorum - пишу на JavaScript';

// проверка наличия паттерна в тексте "text"
console.log(pattern1.test(text));

// поиск позиции слова "JavaScript" в тексте "text"
const position = text.search(pattern2);
console.log(`Позиция слова "JavaScript": ${position}`);
👍3🔥21
This media is not supported in your browser
VIEW IN TELEGRAM
Рубрика разборов возможных вопросов из собеседований по JavaScript 🟨

👉 Где на практике часто используют методы setTimeout и setInterval?

⏲️ setTimeout можно использовать для:
задержки выполнения действий
последовательного выполнения действий
задержки ввода в поле поиска

setInterval можно использовать для:
регулярного обновления интерфейса
повторного запроса на сервер

В видео рассмотрели эти примеры в виде кодов 👁‍🗨
🔥51👍1
Делимся лаконичной светлой CSS-стилистикой для блоков, которую можно назвать трендовой, так как подобная стилистика сейчас часто встречается в UI/UX-дизайне 🎨

Стилизовав контейнеры таким подходом можно добавить пространственности за счёт теней, ненавязчиво намекнуть на наличие блока, внутри которого находится контент, при этом не перегрузив интерфейс деталями 🟦

Как можно заметить, основная реализация такой стилистики заключается в комбинации светлой тени, уходящей в левый верхний угол и несильной тёмной тени, уходящей в правый нижний угол 👁‍🗨

Код со скрина:
.laconic-style {
background: #fff;
border-radius: 16px;

filter:
drop-shadow(-5px -5px 5px #ffffff)
drop-shadow(-10px -10px 15px #d387f850)
drop-shadow( 15px 15px 15px #00000010);

width: 100px;
height: 70px;
margin: 20px;
outline: 2px solid #faf2ff20;
outline-offset: -1px;
}
6👍2🔥2👏1
This media is not supported in your browser
VIEW IN TELEGRAM
useState – это React хук, который используется для контролирования какого-либо локального состояния в компоненте и предоставления обновления этого состояния ⚛️

На гифке пример использования хука useState: есть компонент с надписью и кнопкой ⏏️

"const [count, setCount] = useState(0)" – это состояние, сохраняющее значение переменной count
setCountфункция, обновляющая состояние
значение возле хука "(0)" – это значение переменной count по умолчанию

Также кнопке присвоена функция, увеличивающая значение переменной count на единицу – "onClick={() => setCount(count + 1)}"

Код из гифки:
import React from 'react';
import { useState } from 'react';

const MyComponent = () => {
const [count, setCount] = useState(0);

return (
<div>
<p>Счетчик: {count}</p>

<button onClick={() => setCount(count + 1)}>
добавить
</button>
</div>
);
};

export default MyComponent;
🔥7👍21👏1
Приняли решение поменять дизайн фона вертикальных видео, которые публикуем в соц. сетях 🔮

Хотим узнать ваше мнение, помогите определиться какое дизайнерское решение выглядит более лаконично и презентабельно стилистически 🪁

🔹 Решение №1: текущий дизайн, который определенно хотим поменять
🔹 Решение №2: пространственный фон с мягким объёмным блоком кода
🔹 Решение №3: стильное ребристое стекло, легкий непринуждённый фон

Проголосуйте в следующем посте 👇
👍2❤‍🔥1🔥1🤩1
Какой фон понравился больше всего?
Anonymous Poll
28%
Решение №1 📱
32%
Решение №2 🔭
40%
Решение №3 🪼
👏61👍1🐳1
Что такое конструктор в JavaScript? 🏗

Конструктор – это специальная функция, которая используется для создания и инициализации разных объектов. Основная идея конструкторов заключается в возможности создавать много объектов с одинаковыми свойствами и методами по определенному шаблону 🃏

На скрине пример создания объекта Homer с помощью конструктора Person 🍩

👉 Теперь у объекта есть:
два свойства/параметра: age и hometown
метод speak

Но на практике удобнее пользоваться классами, использование которых в разы проще 👁‍🗨

Код со скрина:
// ✦ объявление конструктора
function Person(age, hometown) {
this.age = age;
this.hometown = hometown;
this.speak = function() {
console.log(`Hi, I'm ${this.age} years old, my hometown is ${this.hometown}`)
};
}

// ✦ создание объекта с помощью конструктора
let Homer = new Person(40, 'Springfield')

Homer.speak();
👍5👏21🔥1🤝1
Как сделать градиентный текст в CSS? 🍡

👉 Благодаря комбинации трёх свойств:

background-image со значением в виде градиента

background-clip со значением text (чтобы градиент обрёл форму текста, к которому применяется класс, вместо формы контейнера элемента текста)

color со значением transparent (градиент применяется к фону контейнера элемента, то есть контейнера текста. Благодаря тому что мы сделаем текст прозрачным за ним будет виден фон контейнера - градиент в форме текста)

Код со скрина:
.gradient-text {
background-image: linear-gradient(90deg, #d815ff, cyan, #414aff);
background-clip: text;
color: transparent;
}
👍5🔥32
This media is not supported in your browser
VIEW IN TELEGRAM
JavaScript – универсальный язык, используемый как на клиентской (frontend), так и на серверной (backend) части. Однако подход к использованию языка значительно отличается 🟨

Фронтенд — это о взаимодействии с пользователем и работе с браузером 🖥

Бэкенд — об управлении логикой, обработке данных и работе с серверными ресурсами. Но синтаксис языка остается схожим 🗄

JavaScript – мост между двумя мирами, и именно это делает его таким популярным ⭐️
🔥3👍21