Exploring Blazor Hybrid Apps Using Mobile Blazor Bindings | Syncfusion Blogs
Detailed Blog page Skeleton loader
Exploring Blazor Hybrid App using Mobile Blazor Bindings

We are in the age of hybrid apps! Single code base, better speed, less development, and fewer maintenance costs are some of the benefits of hybrid apps over other native applications. In this blog post, we are going to create a Blazor hybrid app using the Mobile Blazor Bindings and Syncfusion Blazor UI components.

The Mobile Blazor Bindings is an experimental project that allows developers to build native desktop and hybrid mobile apps using C# and .NET.

The anticipated .NET 6.0 preview 1  which was rolled out on February 17, specially mentions Blazor hybrid apps.

How Blazor hybrid app works?

A Blazor hybrid app uses the embedded WebView control to render the Blazor and other web contents natively on devices instead of using web browsers like the Electron does in cross-platform hybrid applications. In other words, the Blazor components are directly rendered in native devices without using WebAssembly.

Mobile Blazor Bindings hosts the Blazor components in a Xamarin.Forms app. That way, the Blazor components will run natively on .NET using Xamarin and the native functionalities can be accessed through .NET API.

Let’s start creating a Blazor hybrid application using Mobile Blazor Bindings and Syncfusion Blazor UI components!

Syncfusion’s Blazor components suite is the expert’s choice for building modern web apps.

Prerequisites

  1. .NET SDK 3.1 or Later
  2. Visual Studio with the following workloads:
  • ASP.NET and web development.
  • Mobile development with .NET.

Choose ASP.NET and web development and Mobile development with .NET workloads in Visual Studio

  1. The Microsoft Edge Canary Channel is essential to run a Blazor hybrid app on Windows.

    Note: Without this setup, the Blazor hybrid app will not work on Windows.

  1. Install the Mobile Blazor Bindings project template using the following command line in the command prompt.
    dotnet new -i Microsoft.MobileBlazorBindings.Templates::0.5.50-preview

Creating a Blazor hybrid application

Follow these steps to create a new Blazor hybrid application using .NET CLI.

  1. Run this command line to create a new Blazor hybrid application.
    dotnet new blazorhybrid -o BlazorHybridApp

    Run the command dotnet new blazorhybrid -o BlazorHybridApp to create a Blazor Hybrid appThe Blazor hybrid application is now created. You can see the separate projects for Android, iOS, Windows and macOS along with the Blazor core project where the UI logics will be added.
    Solution window showing different projects listThe Blazor core project includes the Blazor components and UI logics for the hybrid application.Blazor core project showing the Blazor components and UI logicsThe Mobile Blazor Bindings project has some default, native Xamarin.Forms controls. You can explore the ~/BlazorHybridApp/Main.razor file where the native and Blazor WebView controls are rendered.
    The native Xamarin and Blazor WebView controls in Main.razor file

  1. Now, set any platform-specific project as the startup project. For example, let’s choose the BlazorHybridApp.Windows to create a hybrid project in Windows.
  2. Then, run the application. It will expose the default native layout like in the below image.

    Blazor hybrid default app running on windows
    Blazor hybrid default app running on windows

Everything a developer needs to know to use Blazor components in the Blazor app is completely documented.

Add Syncfusion Blazor components to the Blazor hybrid app

Follow these steps to include Syncfusion Blazor UI components in your Blazor hybrid app:

  1. First, open the Blazor core project file (BlazorHybridApp.csproj).
  2. Then, change the TargetFramework from netstandard2.0 to netstandard2.1, since the Syncfusion Blazor components only support netstandard2.1.
  3. Install the required Syncfusion individual Blazor NuGet packages in the Blazor core project. For this example, let’s add the Syncfusion.Blazor.Grid NuGet package.
  4. Now, open the ~/App.cs file in the Blazor core project and add the Syncfusion service in the ConfigureServices section.
    using Syncfusion.Blazor;
    
    public class App : Application
        {
            public App(IFileProvider fileProvider = null)
            {
                var hostBuilder = MobileBlazorBindingsHost.CreateDefaultBuilder()
                    .ConfigureServices((hostContext, services) =>
                    {
                        ......
                        ......
                        // Register Syncfusion Blazor service
                        services.AddSyncfusionBlazor();
                    })
                    .UseWebRoot("wwwroot");
    
                ......
                ......
            }
            ......
            ......
        }
  5. Then, add the below Syncfusion CSS style reference in each platform-specific project’s ~/wwwroot/index.html file.
    <!DOCTYPE html>
    <html>
    
    <head>
        ......
        ......
    
        <link href="_content/Syncfusion.Blazor.Themes/bootstrap4.css" rel="stylesheet" />
    </head>
    ......
    ......
    </html>
  6. Now, add the Syncfusion Blazor DataGrid (SfGrid) component in the ~/WebUI/Pages/Index.razor file in the Blazor core project.
    @using Syncfusion.Blazor.Grids;
    
    <h1>Syncfusion Blazor Grid component</h1>
    
    <SfGrid DataSource="@Orders" AllowPaging="true">
        <GridPageSettings PageSize="5"></GridPageSettings>
        <GridColumns>
            <GridColumn Field=@nameof(Order.OrderID) HeaderText="Order ID" TextAlign="TextAlign.Right" Width="120"></GridColumn>
            <GridColumn Field=@nameof(Order.CustomerID) HeaderText="Customer Name" Width="150"></GridColumn>
            <GridColumn Field=@nameof(Order.OrderDate) HeaderText=" Order Date" Format="d" Type="ColumnType.Date" TextAlign="TextAlign.Right" Width="130"></GridColumn>
            <GridColumn Field=@nameof(Order.Freight) HeaderText="Freight" Format="C2" TextAlign="TextAlign.Right" Width="120"></GridColumn>
        </GridColumns>
    </SfGrid>
    
    @code{
        public List<Order> Orders { get; set; }
    
        protected override void OnInitialized()
        {
            Orders = Enumerable.Range(1, 75).Select(x => new Order()
            {
                OrderID = 1000 + x,
                CustomerID = (new string[] { "ALFKI", "ANANTR", "ANTON", "BLONP", "BOLID" })[new Random().Next(5)],
                Freight = 2.1 * x,
                OrderDate = DateTime.Now.AddDays(-x),
            }).ToList();
        }
    
        public class Order
        {
            public int? OrderID { get; set; }
            public string CustomerID { get; set; }
            public DateTime? OrderDate { get; set; }
            public double? Freight { get; set; }
        }
    }
  7. Finally, run the application. The Syncfusion Blazor components will render on the native desktop or hybrid mobile layout.
Syncfusion Blazor Grid rendered on android mobile
Syncfusion Blazor DataGrid rendered on Android simulator
Syncfusion Blazor Grid rendered on windows desktop
Syncfusion Blazor DataGrid rendered on windows desktop

Explore the different application UIs developed using Syncfusion Blazor components.

Does Mobile Blazor Bindings work on Syncfusion Xamarin components?

As of now, Syncfusion Xamarin components do not support Mobile Blazor Bindings, but we have logged a feature request for this.

Reference

For more information, you can check out the Exploring Blazor hybrid apps using Mobile Blazor Bindings with Syncfusion Blazor components demo.

Summary

Thanks for reading! In this blog post, we have learned how to create a Blazor hybrid app using Mobile Blazor Bindings and Syncfusion Blazor UI components. Blazor hybrid apps are still an experimental project and we are eagerly waiting for their full support. What do you think about this blog post? Please leave feedback in the comments section!

Syncfusion’s  Blazor package offers over 65 high-performance, lightweight, and responsive UI components for the web, including file-format libraries, in a single package. Use them to enhance your productivity while developing apps!

For existing customers, the newest version is available for download from the License and Downloads page. If you are not yet a Syncfusion customer, you can try our 30-day free trial to check out our available features. Also, try our samples from this GitHub location.

You can contact us with questions or comments through our support forumsDirect-Trac, or feedback portal. We are always happy to assist you!

If you like this blog post, we think you’ll also like the following articles too:

Be the first to get updates

Ajith R

Meet the Author

Ajith R

Ajith is the Product Manager for Syncfusion Web Platforms. He has designed and developed the core architecture for Syncfusion JavaScript and Blazor components. He is passionate about web technology and has been active in web development since 2013.

Comments (6)

Is it possible to run the same Blazor project in the Web Browser? and how would you do it?

@ Rizaan  

No, It is not possible to run the Mobile Blazor Binding (MBB) project directly in the web browser. The MBB is a hybrid app to run the Blazor components on native desktop and mobile applications.

Hello,
What about MAUI ? MAUI support Blazor. Can we suppose that Syncfusion.Blazor will be usable in MAUI as well ?

@ Max  

Hi MAX,

Yes, our Syncfusion Blazor components can be rendered in .NET 6 MAUI using Visual Studio 2022.

Regards,
Rajendran R

Is it possible to publish our Android app which is we developed with Mobile Blazor Bindings on Google Play Store?

@ Devrim Akdas  

Hi Devrim,

We didn’t try to publish a app which is developed using Mobile Blazor binding yet. The mobile Blazor binding concept introduced to build hybrid mobile apps. Also, the app looks similar to Xamarin app. So, you can publish an app in Google Play Store.

Regards,
Rajendran R.

Comments are closed.