@PTPPAction · Post #1752 · 27.03.2024 г., 08:10
#dev#IITII#merged fix(mt): 批量下载, 详情页下载 #1762
TGINSIGHT SIMILAR POSTS
Изходен канал @clockstackwheels · Post #32 · 29.05
Попробовал, наконец, разработку на 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
Hashtags
Общо глобално търсене
@PTPPAction · Post #1752 · 27.03.2024 г., 08:10
#dev#IITII#merged fix(mt): 批量下载, 详情页下载 #1762
@PTPPAction · Post #1747 · 27.03.2024 г., 03:10
#dev#IITII#merged fix: HDPost, JoyHD, SSD, HDCity, rousi Level Requirements #1755
@PTPPAction · Post #1744 · 27.03.2024 г., 02:55
#dev#IITII#merged fix(gtru): support uploads (#1772)
@PTPPAction · Post #1734 · 26.03.2024 г., 16:30
#dev#IITII#merged fix(imdb): log
@PTPPAction · Post #1714 · 25.03.2024 г., 08:55
#dev#IITII#merged site(mt): defaultQuickLinks
@PTPPAction · Post #1711 · 25.03.2024 г., 08:50
#dev#IITII#merged site(mt): bonusPerHour
@PTPPAction · Post #1708 · 25.03.2024 г., 06:45
#dev#IITII#merged site(mt): x-api-key in header
@PTPPAction · Post #1705 · 25.03.2024 г., 03:40
#dev#IITII#merged site(ourbits): cdn
@PTPPAction · Post #1690 · 24.03.2024 г., 08:20
#dev#IITII#merged fix(discfan&hd4fans): seedingSize (#1764)
@PTPPAction · Post #1680 · 21.03.2024 г., 08:05
#dev#IITII#merged feat(gtk): 适配新站点 gtk (#1760)
@PTPPAction · Post #1674 · 19.03.2024 г., 15:05
#dev#IITII#merged feat: add kufirc (#1756)
@PTPPAction · Post #1669 · 18.03.2024 г., 06:40
#dev#IITII#merged fix: 新版刷新仅限 Chromium 内核浏览器