Blazor

Blazor چیست؟

Blazor یک چارچوب وب فرانت اند دات نت است که از رندر server-side و Client-side  در یک مدل برنامه نویسی واحد پشتیبانی می کند.

در Blazor می توانید:

  • با استفاده از سی شارپ، UI های تعاملی غنی ایجاد کنید.
  • منطق برنامه سمت سرور و سمت کلاینت نوشته شده در دات نت را به اشتراک بگذارید.
  • برای پشتیبانی گسترده مرورگر، از جمله مرورگرهای تلفن همراه، رابط کاربری را به صورت HTML و CSS ارائه دهید.
  • با دات نت و Blazor برنامه های ترکیبی دسکتاپ و موبایل بسازید.

 استفاده از دات نت برای توسعه وب سمت مشتری مزایای زیر را ارائه می دهد:

  • کد های خود را در سی شارپ می بنویسید، که می تواند بهره وری در توسعه و نگهداری برنامه را بهبود بخشد.
  • از اکوسیستم دات نت موجود کتابخانه های دات نت استفاده کنید.
  • از عملکرد، قابلیت اطمینان و امنیت دات نت بهره مند شوید.
  • می توانید با یک محیط توسعه مانند Visual Studio یا Visual Studio Code در Windows، Linux، یا macOS کار کنید و پلتفرم های میزبانی مدرن مانند Docker ادغام شوید.

کامپوننت ها در Blazor

برنامه های Blazor بر اساس Component هستند. یک Component در Blazor یک عنصر از UI است، مانند صفحه، گفتگو یا فرم ورود داده.

کامپوننت‌ ها کلاس‌های C# هستند که در اسمبلی NET تعبیه شده‌اند که:

  • منطق رندر رابط کاربری انعطاف پذیر
  • مدیریت رویدادهای کاربر
  • قابل تودرتو و استفاده مجدد
  • می توان به صورت کتابخانه های کلاس Razor یا بسته های NuGet به اشتراک گذاشته و توزیع کرد.

کلاس کامپوننت معمولاً به شکل صفحه نشانه گذاری Razor با پسوند فایل .razor نوشته می شود. کامپوننت ها در Blazor به طور رسمی به عنوان اجزای Razor و به طور غیر رسمی به عنوان اجزای Blazor شناخته می شوند. Razor یک نحو برای ترکیب نشانه گذاری HTML با کد C# است که برای بهره وری توسعه دهندگان طراحی شده است.

با Blazor یک برنامه FullStack بسازید

Blazor Web App  یک معماری مبتنی بر کامپوننت را با رندر سمت سرور و تعامل کامل سمت کلاینت در یک solution ارائه می دهد، که در آن می توانید بین حالت های رندر سمت سرور و سمت کلاینت جابجا شوید و حتی آنها را در همان صفحه ترکیب کنید.

Blazor Web Apps  می‌تواند با رندر کردن استاتیک محتوای HTML از سرور در پاسخ به درخواست‌ها، UI  را به سرعت به مرورگر ارائه دهد. صفحه به سرعت بارگیری می شود زیرا رندر رابط کاربری به سرعت در سرور بدون نیاز به دانلود یک بسته بزرگ جاوا اسکریپت انجام می شود.  Blazor همچنین می‌تواند تجربه کاربر را با progressive enhancement  های مختلف در رندر سرور، مانند enhanced navigation  با streaming rendering محتوای تولید شده به ‌صورت ناهمزمان، بهبود بخشد.

Blazor از رندر تعاملی سمت سرور(interactive SSR) پشتیبانی می کند، که در آن تعاملات UI از سرور از طریق یک اتصال بلادرنگ با مرورگر انجام می شود.  SSR تعاملی یک تجربه کاربری غنی را که از یک client app انتظار می رود، را بدون نیاز به API endpoint ها برای دسترسی به منابع سرور امکان پذیر می کند.

Blazor Web App از تعامل با رندر سمت کلاینت (CSR) که بر .NET runtime ساخته شده با WebAssembly متکی است را پشتیبانی می کند. هنگام اجرای Blazor در WebAssembly، کد دات نت شما می تواند به عملکرد کامل مرورگر دسترسی داشته باشد و با جاوا اسکریپت تعامل داشته باشد.

برنامه های Blazor می توانند به طور کامل اجرا بر روی WebAssembly در مرورگر را بدون دخالت سرور هدف قرار دهند. برای یک standalone Blazor WebAssembly app، asset ها به عنوان فایل های ثابت در یک وب سرور یا سرویسی که قادر به ارائه محتوای ثابت به کلاینت است، مستقر می شوند. پس از دانلود، standalone Blazor WebAssembly app را می‌توان کش کرد و به صورت آفلاین به عنوان یک برنامه وب پیشرو (PWA) اجرا کرد.

با Blazor Hybrid یک native client app بسازید

Blazor Hybrid استفاده از کامپوننت های Razor را در یک native client app با ترکیبی از فناوری‌های بومی native و وب برای پلتفرم‌های وب، موبایل و دسکتاپ امکان‌پذیر می‌کند. کد به صورت بومی در فرآیند دات نت اجرا می شود و UI وب را با استفاده از یک interop محلی به یک کنترل Web View تعبیه شده ارائه می کند . WebAssembly در برنامه های هیبریدی استفاده نمی شود. برنامه‌های هیبریدی با .NET Multi-platform App UI (.NET MAUI) که یک چارچوب چند پلتفرمی برای ایجاد برنامه‌های بومی موبایل و دسکتاپ با C# و XAML است، ساخته شده‌اند.

Blazor Hybrid از Windows Presentation Foundation (WPF) و Windows Forms برای انتقال برنامه‌ها از فناوری قبلی به NET MAUI پشتیبانی می‌کند.