Попробовал, наконец, разработку на Blazor. Это такой фреймворк под .NET, который позволяет писать фронтенд на C#. Работает он двумя способами: либо собирает весь проект в WebAssembly, и бедный пользователь грузит себе мегабайтную dll, либо устанавливает клиент-серверное соединение через SignalR и шлёт клиенту информацию об обновлённых DOM-элементах.
Вот вторую то я и пробовал. Казалось бы — каждое нажатие кнопки требует отправить на сервер запрос и получить ответ. Никогда такого не было! Но субъективно разницы во времени отклика нет (потому что веб и так достаточно медленный, хаха).
Фронтенд-часть пишется очень похоже на JSX: вёрстка реактивно вперемешку с кодом. Когда-то я очень ругал React за такой подход, потому что каша. Но нетипизированный JS по-умолчанию каша, а здесь же по факту получается очень удобно: статический анализ не даёт тебе делать ошибки и писать ерунду.
Но приятный полноценный язык программирования вместо JavaScript это лишь вишенка на торте. Самое крутое — вся сила серверного кода с полноценной возможностью обращения к базе данных, шеринг моделей данных между сервером и клиентом, и, наконец, Dependency Injection любого серверного модуля в «клиент»! То есть вы не просто пишете одно приложение вместо двух, вы ещё и получаете отсутствие ошибок при каком-нибудь изменении моделей API, когда сервер стал отдавать не то, что ожидает клиент. Вам вообще теперь не нужен API, достаточно закодить нужную функцию на серваке и инжектировать её в нужный фронтенд-модуль.
Это супер удобно, супер быстро, супер устойчиво к ошибкам. Теперь не хочется возвращаться даже на вполне крутой Vue 3. Но, система пока новая, она не обросла решениями от комьюнити, а браузерный API всё равно придётся дергать через JavaScript Interop. Для совсем кайфа нужно подождать годик, поскольку развитие идёт довольно быстро. Например, там нет очень нужного в таком деле hot reload, но в .NET 6 он уже анонсирован, и вроде как есть в превью, а релиз в ноябре.
#dev
Date A Live Fragment: Parte 2 Nightmare or Queen
Año 2020
Duración 24 min.
País Japón
🎬Dirección#JunNakagawa
📖Guion Yuichiro Higashide
📕Novela#YuichiroHigashide
Productora Geek Toys
Género#Animación#Comedia#Romance#Cienciaficción#Cortometraje#Spinoff#Secuela
Trailer / Sinopsis
Ver Aquí
Parte 1 Date a Bullet
Balto II: Wolf Quest
aka Balto 2: Aventura en la Tierra del Hielo
📅Año 2002
⏱Duración 76min.
🎥Dirección#PhilWeinstein
📄Guion Dev Ross
👤Personajes Cliff Ruby, Eliana Lesser
🎼Música Adam Berry
🎬Productora Universal Cartoon Studios
Género#Animación#Aventuras#Secuela#Perros#Lobos#Siberiano
Reparto | Trailer | Sinopsis
Ver Aquí
SagaBalto