Заметки разработчика
473 subscribers
667 photos
4 videos
1.16K links
Заметки о Frontend, Backend и немного DevOps. В основном о #PHP, #Laravel, #JavaScript, #HTML, #CSS, тестировании и настройке серверов.

https://www.dev-notes.ru

@snakenf
Download Telegram
У вас есть связь, в которой нужна только самая последняя или самая старая связанная модель?

Используйте latestOfMany() или oldestOfMany() с hasOne(), для доступа только к одной записи, без сложных подзапросов.

🖥 Ссылка на документацию

📱 @dev_notes_ru

#Laravel #tips
Please open Telegram to view this post
VIEW IN TELEGRAM
👩‍💻 this в JavaScript: Когда определяется this

Ключевое слово this в JavaScript ставит в тупик всех разработчиков — от джунов до сеньоров. В первой из двух частей углубимся в основы, необходимые для лучшего понимания this и того, как он работает.

🖥 Читать статью

📱 @dev_notes_ru

#JavaScript #this
Please open Telegram to view this post
VIEW IN TELEGRAM
1👍1
👩‍💻 Типизированные геттеры для хелперов `Arr`

Anthony Tibbs создал типизированные хелперы геттеров класса поддержки Arr для array, boolean, float, integer и string. Каждый метод попытается вернуть тип и выбросит исключение, если данные не соответствуют типу:

use Illuminate\Support\Arr;
$array = ['name' => 'Joe', 'languages' => ['PHP', 'Ruby']];

$value = Arr::array($array, 'languages'); // ['PHP', 'Ruby']
$value = Arr::array($array, 'name'); // throws InvalidArgumentException


🖥 Pull Request #55567

📱 @dev_notes_ru

#Laravel12 #tips
Please open Telegram to view this post
VIEW IN TELEGRAM
👩‍💻 Преобразование значений в строки в JavaScript

Руководство по преобразованию значений в строки в JavaScript: сравнение 5 методов, работа с объектами и JSON.stringify(), практические примеры и лучшие практики.

Преобразование значений в строки в JavaScript сложнее, чем кажется:

- В большинстве подходов есть значения, которые они не могут обработать.
- Мы не всегда видим все данные.

🖥 Читать статью

📱 @dev_notes_ru

#JavaScript
Please open Telegram to view this post
VIEW IN TELEGRAM
👍1
👩‍💻 В полезную нагрузку заданий добавлены `createdAt` и `delay`

Taylor Otwell внес вклад в добавление информации о создании и задержке задания в полезную нагрузку задания. delay - опциональная задержка задания в секундах, а createdAt - timestamp момента создания полезной нагрузки:

$job->payload();
/*
Теперь включает: ['delay' => 5, 'createdAt' => 1745965273]
*/


🖥 Pull Request #55529

📱 @dev_notes_ru

#Laravel12 #tips
Please open Telegram to view this post
VIEW IN TELEGRAM
👩‍💻 Внутреннее устройство React: Какой useEffect запускается первым?

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

useEffect — один из наиболее часто используемых хуков в сообществе React. Независимо от того, сколько у вас опыта работы с React, вы наверняка его уже использовали.

Но приходилось ли сталкиваться с ситуациями, когда хуки useEffect запускаются в неожиданном порядке, если задействовано несколько слоев компонентов?

🖥 Читать статью

📱 @dev_notes_ru

#React #useEffect
Please open Telegram to view this post
VIEW IN TELEGRAM
👏1
👩‍💻 Убедитесь, что фейковое задание реализует контракт задания

Tim MacDonald добавил контракт Illuminate\Contracts\Queue\Job в класс FakeJob, используемый в тестах для имитации заданий в очереди:

Имитация задания используется в тех местах, где ожидается реализация контракта задания.

Это гарантирует, что фейковое задание поддерживает строгую типизацию контракта задания, например, при прослушивании событий и передаче экземпляра задания.


🖥 Pull Request #55574

📱 @dev_notes_ru

#Laravel12 #tips
Please open Telegram to view this post
VIEW IN TELEGRAM
Пользователи Linux вернувшиеся в Linux после 10 минут использования Windows

📱 @dev_notes_ru

#joke
Please open Telegram to view this post
VIEW IN TELEGRAM
👍2🥰1🤣1
Всего через шесть месяцев вайб-кодинга

📱 @dev_notes_ru

#joke
Please open Telegram to view this post
VIEW IN TELEGRAM
😁3🤣1
💡 Совет по Laravel: Многоразовые конвейеры

Конвейеры позволяют разделить большую задачу на более мелкие и управляемые. Иногда требуется использовать один и тот же конвейер в разных местах, и оказалось, что Laravel позволяет определять многоразовые конвейеры из коробки 🚀.

📱 @dev_notes_ru

#Laravel #Pipeline #tips
Please open Telegram to view this post
VIEW IN TELEGRAM
👍21
👩‍💻 Error.isError(): Лучший способ проверки типов ошибки в JavaScript

Руководство по новому методу `Error.isError()` в JavaScript: почему он лучше `instanceof`, как решает проблемы кросс-контекстных ошибок и типизации в TypeScript.

Система обработки ошибок JavaScript долгое время оставалась слепым пятном при работе с ошибками в разных контекстах исполнения. Новый метод Error.isError() устраняет это ограничение, предоставляя разработчикам более надёжный способ идентификации объектов ошибок.

🖥 Читать статью

📱 @dev_notes_ru

#JavaScript
Please open Telegram to view this post
VIEW IN TELEGRAM
👍1
Laravel Enum: Чистый, структурированный и удобный для разработчиков

Теперь Laravel поддерживает нативные классы Enum со встроенными функциями кастинга, меток и генерации через Artisan. Это отличный способ избавиться от "магических" строк и чисел в моделях и формах.

🔧 Создание Enum через Artisan:

php artisan make:enum UserRole


📁 Создастся файл: app/Enums/UserRole.php

📦 Пример класса Enum:

namespace App\Enums;

enum UserRole: string
{
case Admin = 'admin';
case Manager = 'manager';
case Customer = 'customer';

public function label(): string
{
return match($this) {
self::Admin => 'Администратор',
self::Manager => 'Менеджер',
self::Customer => 'Клиент',
};
}

public static function options(): array
{
return array_map(
fn($role) => ['value' => $role->value, 'label' => $role->label()],
self::cases()
);
}
}


Как использовать:

📌 Приведение типов в модели:

protected $casts = [
'role' => UserRole::class,
];


📌 Работа с Enum:

$user->role = UserRole::Admin;
echo $user->role->label(); // "Администратор"


📌 Генерация <select> (Blade или Livewire):

<select name="role">
@foreach (App\Enums\UserRole::options() as $option)
<option value="{{ $option['value'] }}">{{ $option['label'] }}</option>
@endforeach
</select>


📌 Валидация ввода:

'role' => ['required', new Enum(UserRole::class)],


📌 Laravel Enums делают код чище, улучшают его читаемость и уменьшают количество ошибок, связанных с недопустимыми значениями. Используйте make:enum, для быстрого создания, и расширяйте функциональность по мере необходимости.

📱 @dev_notes_ru

#Laravel
Please open Telegram to view this post
VIEW IN TELEGRAM
👍3🤣1
👩‍💻 Что такое this в JavaScript

Во второй части серии Mat Marquis объясняет, что такое this на самом деле, и помогает разобраться, чему он соответствует, исходя из различных контекстов.

🖥 Читать статью

📱 @dev_notes_ru

#JavaScript
Please open Telegram to view this post
VIEW IN TELEGRAM
👍1
Laravel 12.6: Новый метод `requestException()` для удобной обработки ошибок HTTP-тестов

Laravel 12.6 представляет метод requestException() — более простой способ создания экземпляров RequestException при тестировании работы HTTP-клиента. Теперь можно эмулировать ошибочные ответы сервера чище и лаконичнее.

🔧 Как это работало раньше:

use Illuminate\Http\Client\RequestException;
use Illuminate\Http\Client\Response;

$exception = new RequestException(
new Response(
Http::response(['error' => 'invalid_token'], 401)
)
);


Теперь с `requestException()`:

use Illuminate\Support\Facades\Http;

$exception = Http::requestException(['error' => 'invalid_token'], 401);


Нужны кастомные заголовки? Просто передайте их:

$exception = Http::requestException(
['message' => 'Too many requests'],
429,
['X-RateLimit-Reset' => '30']
);


Почему это удобно:

- Меньше шаблонного кода в тестах
- Лучшая читаемость и понятность
- Упрощает поддержку и рефакторинг

📌 Метод requestException() делает HTTP-тесты чище, быстрее и выразительнее.

📱 @dev_notes_ru

#Laravel #Laravel12
Please open Telegram to view this post
VIEW IN TELEGRAM
👩‍💻 Мемоизация кэша в Laravel: Как работает `Cache::memo()` и зачем он нужен

Как использовать мемоизацию кэша в Laravel для повышения производительности и сокращения сетевых обращений к Redis, Memcached и другим хранилищам.

Даже если вы используете кэш, Laravel каждый раз обращается к внешнему хранилищу. Это может быть Redis или Memcached — и каждый такой запрос может занимать лишние миллисекунды. В больших приложениях это превращается в серьёзную нагрузку.

🖥 Читать статью

📱 @dev_notes_ru

#Laravel #Cache
Please open Telegram to view this post
VIEW IN TELEGRAM
👍1🔥1
Отключение событий при создании Eloquent моделей

При тестировании часто возникает необходимость создавать записи через модель без запуска связанных событий. Сделать это очень просто с помощью метода createQuietly.

Пример использования со стандартной моделью:

$user = User::createQuietly([
'name' => 'Mabel',
'email' => 'mabel@codecourse.com'
]);


Метод createQuietly не запускает никакие события, поэтому обработчики в наблюдателях моделей не сработают.

Особенно удобно при тестировании с фабриками:

User::factory(3)->createQuietly();


Этот код создаст трёх пользователей без генерации событий.

Другие варианты "тихого" создания:

- createOneQuietly() - для создания одной записи
- createManyQuietly() - для массового создания

Эти методы помогают ускорить тесты и избежать побочных эффектов при работе с моделями.

📱 @dev_notes_ru

#Laravel #Eloquent #tips
Please open Telegram to view this post
VIEW IN TELEGRAM
👍3
PHP разработчики vs. Хэйтеры PHP

📱 @dev_notes_ru

#joke
Please open Telegram to view this post
VIEW IN TELEGRAM
👍3😁3🤣1
- Я использую C++ в JavaScript
- Покажи

📱 @dev_notes_ru

#joke
Please open Telegram to view this post
VIEW IN TELEGRAM
🤣7🔥3😎1
Проверка существования представления в Laravel

Если вы работаете с представлениями в Laravel напрямую и нужно заранее проверить, существует ли представление, вот как это сделать.

Это очень просто! Просто используйте метод exists класса View. В данном примере используется хелпер view.

if (view()->exists('some.view')) {
// ...
}


Учтите, что some.view соответствует файлу /some/view.blade.php. Этот метод работает с точечной нотацией так же, как и при рендеринге представлений.

📱 @dev_notes_ru

#Laravel #View #tips
Please open Telegram to view this post
VIEW IN TELEGRAM
2👍1
Что-то пошло не так

📱 @dev_notes_ru

#joke
Please open Telegram to view this post
VIEW IN TELEGRAM
👍4🔥1🤣1
В случае пожара

📱 @dev_notes_ru

#joke
Please open Telegram to view this post
VIEW IN TELEGRAM
😱1🤣1