Logo

dev-resources.site

for different kinds of informations.

How to Easily Load JSON Data in .NET MAUI TreeView?

Published at
1/9/2025
Categories
netmaui
development
mobile
ui
Author
zahrasandran
Categories
4 categories in total
netmaui
open
development
open
mobile
open
ui
open
Author
12 person written this
zahrasandran
open
How to Easily Load JSON Data in .NET MAUI TreeView?

TL;DR: Let’s see how to load JSON data into the .NET MAUI TreeView effortlessly. This blog guides you through fetching JSON data from a URI, storing it locally, and binding it to the TreeView control. Perfect for creating intuitive navigation and hierarchical data views in .NET MAUI apps!

The Syncfusion .NET MAUI TreeView (SfTreeView) control displays data in a tree structure, letting you expand and collapse nodes. It is optimized for smooth scrolling and efficient data reuse. You can bind data, create nodes, and customize the UI easily. It also supports different selection modes, complete UI customization, and MVVM commands for better performance.

This blog teaches you how to visualize JSON data in the .NET MAUI TreeView with a hierarchical structure.

Data can be populated in the TreeView in two different modes:

  • Bound and
  • Unbound modes.

Here, we’ll bind JSON data in the .NET MAUI TreeView in bound mode using the ItemsSource property.

Let’s get started!

Populate JSON data collection from a URI

In modern mobile app development, fetching data from remote sources and storing it locally for offline use or caching purposes is essential. With .NET MAUI, you’ll often need to retrieve JSON data from a URI and store it for later access.

Here’s how to do this efficiently in a few steps.

Step 1: Install the Newtonsoft.Json NuGet package

To easily work with JSON data in .NET MAUI, you’ll need the Newtonsoft.Json library. This popular library allows you to serialize and deserialize JSON data with ease. To do so,

  • In your .NET MAUI project, open the NuGet Package Manager.
  • Search for Newtonsoft.Json.
  • Then, install the latest stable version of the package.

This library is essential for converting your JSON string into objects and vice versa.

Step 2: Download JSON data using HttpClient and store it locally

Now that you have the necessary library installed, the next step is to fetch the JSON data from a URI, deserialize it, and store it locally on the device.

Refer to the following code example.

public async Task<bool> DownloadJsonAsync()
{
    try
    {
        // Set your REST API url here
        var url = "https://jayaleshwari.github.io/treeview-json-data/TaskDetails.json";

        // Sends request to retrieve data from the web service for the specified Uri
        var response = await httpClient.GetAsync(url);

        using (var stream = await response.Content.ReadAsStreamAsync()) // Reads data as stream
        {
            // Gets the path to the specified folder
            var localFolder = System.Environment.GetFolderPath(System.Environment.SpecialFolder.LocalApplicationData);
            var newpath = Path.Combine(localFolder, "Data.json"); // Combine path with the file name

            var fileInfo = new FileInfo(newpath);
            File.WriteAllText(newpath, String.Empty); // Clear file content

            // Creates a write-only file stream
            using (var fileStream = fileInfo.OpenWrite())
            {
                // Reads data from the current stream and writes to the destination stream (fileStream)
                await stream.CopyToAsync(fileStream);
            }
        }
    }
    catch (OperationCanceledException e)
    {
        System.Diagnostics.Debug.WriteLine(@"ERROR {0}", e.Message);
        return false;
    }
    catch (Exception e)
    {
        System.Diagnostics.Debug.WriteLine(@"ERROR {0}", e.Message);
        return false;
    }

    return true;
}
Enter fullscreen mode Exit fullscreen mode

Populating tree hierarchy using .NET MAUI TreeView and JSON data

Using TreeView is an effective solution in scenarios where you need to visualize hierarchical data. When the data source is a JSON file, you can bind it to the ItemsSource property of the .NET MAUI TreeView control and display it in a tree structure.

Step 1: Define a model class matching the JSON structure

Let’s define a model class that matches the structure of the JSON data. For example, if your JSON data represents a collection of tasks, each task may have subtasks, and so on.

Refer to the following code example.

public class TaskDetails
{        
    public int TaskID { get; set; }
    public string TaskName { get; set; }        
    public DateTime StartDate { get; set; }
    public DateTime EndDate { get; set; }
    public double Duration { get; set; }
    public string Progress { get; set; }
    public string Priority { get; set; } // Corrected the typo "Pirority" to "Priority"
    public bool IsParent { get; set; }

    public ObservableCollection<TaskDetails> SubTaskDetails { get; set; }

    internal int ParentItem { get; set; }

    public TaskDetails()
    {
        SubTaskDetails = new ObservableCollection<TaskDetails>();
    }
}
Enter fullscreen mode Exit fullscreen mode

In this example, the SubTaskDetails allows each task to have children, which is essential for representing hierarchical data in a tree structure.

To properly bind data in the SfTreeView.ItemsSource with the MVVM pattern in .NET MAUI, the ViewModel must define a property that will hold the data collection. This collection will be bound to the ItemsSource of the SfTreeView.

In this scenario, we will define a property in the ViewModel, typically as an ObservableCollection, which will update the view automatically when the data changes.

Refer to the following code example.

public class TreeViewViewModel : INotifyPropertyChanged
{
    private IList<TaskDetails> jsonCollection;

    public IList<TaskDetails> JSONCollection
    {
        get
        {
            return jsonCollection;
        }
        set
        {
            jsonCollection = value;
            OnPropertyChanged(nameof(JSONCollection));
        }
    }
}
Enter fullscreen mode Exit fullscreen mode

Step 2: Load JSON data and deserialize it into the ViewModel

Next, load the JSON data and deserialize it into a collection of TaskDetails objects. To download and deserialize the JSON data, follow the pattern described earlier.

private async void GenerateSource()
{
    isDownloaded = await DataService.DownloadJsonAsync();

    if (isDownloaded)
    {
        var localFolder = Environment.GetFolderPath(Environment.SpecialFolder.LocalApplicationData);
        var fileText = File.ReadAllText(Path.Combine(localFolder, "Data.json"));

        // Read data from the local path and set it to the collection bound to the ListView.
        JSONCollection = JsonConvert.DeserializeObject<IList>(fileText);                
    }
}
Enter fullscreen mode Exit fullscreen mode

Step 3: Configure the .NET MAUI TreeView in XAML

In your XAML file, define the .NET MAUI TreeView control and bind it to the data model. The ItemsSource property will be bound to the collection of tasks, and the hierarchical structure will be defined by the ChildPropertyName.

<syncfusion:SfTreeView x:Name="treeView" 
                       ItemTemplateContextType="Node"                          
                       ItemsSource="{Binding JSONCollection}"                           
                       ChildPropertyName="SubTaskDetails"/>

Enter fullscreen mode Exit fullscreen mode

Refer to the following image.

<alt-text>


Loading JSON data in .NET MAUI TreeView

GitHub reference

For more details, refer to the loading JSON data in the .NET MAUI TreeView GitHub demo.

Conclusion

Thanks for reading! Following these steps, you can successfully populate the Syncfusion .NET MAUI TreeView with JSON data. This allows you to present hierarchical data structures in a user-friendly way. Combining the Newtonsoft.Json package for data handling and TreeView for visualization makes it easy to implement dynamic, tree-like interfaces in your .NET MAUI apps.

Existing customers can access the new version of Essential Studio® on the License and Downloads page. If you aren’t a Syncfusion customer, try our 30-day free trial to experience our fantastic features.

Feel free to reach out via our support forum, support portal, or feedback portal. We’re here to help!

Related blogs

netmaui Article's
30 articles in total
Favicon
Introducing the New .NET MAUI Bottom Sheet Control
Favicon
Create Stunning AI-Powered .NET MAUI Charts Using Natural Language
Favicon
How to Easily Load JSON Data in .NET MAUI TreeView?
Favicon
Transform JSON into Stunning Charts: Auto-Generate Visuals with SyncfusionŽ .NET MAUI Toolkit 
Favicon
Visualizing Skyscraper Data with .NET MAUI Doughnut Chart and Maps
Favicon
Syncfusion EssentialÂŽ UI Kit for .NET MAUI: Accelerate App Development with Pre-Built UI Pages
Favicon
Building a Neumorphic UI with .NET MAUI Column Chart to Showcase Gen Z’s Favourite Social Media Platforms
Favicon
Introducing Syncfusion’s Second Set of Open-Source .NET MAUI Controls
Favicon
Sneak Peek at 2024 Volume 4: .NET MAUI
Favicon
Create a .NET MAUI Spline Area Chart to Track Annual Gold Price Fluctuations Across Major Global Currencies
Favicon
Visualize U.S. Gulf Coast Kerosene-Type Jet Fuel Prices with .NET MAUI Fast Line Chart
Favicon
Introducing Syncfusion’s First Set of Open-Source .NET MAUI Controls
Favicon
Introducing the New .NET MAUI AI AssistView Control
Favicon
AI-Powered Smart .NET MAUI Scheduler for Easy Appointment Booking
Favicon
AI-Driven Smart PDF Form Filling in .NET MAUI PDF Viewer
Favicon
AI-Driven Smart Location Search in .NET MAUI Maps
Favicon
AI-Powered Smart Searching in .NET MAUI Autocomplete
Favicon
Integrating AI-Powered Smart Paste in .NET MAUI DataForm for Easy Data Entry
Favicon
Syncfusion Essential Studio 2024 Volume 3 Is Here!
Favicon
Chart of the Week: Create a .NET MAUI Drill-Down Chart to View U.S. Workforce Distribution by Industry
Favicon
Sneak Peek 2024 Volume 3: AI-Powered Smart .NET MAUI controls
Favicon
Chart of the Week: Creating a .NET MAUI Radar Chart to Visualize Wind Directions
Favicon
Creating a Custom Chatbot with OpenAI APIs | Blazor and .NET MAUI Integration (Workshop Show Notes)
Favicon
بهترین آموزش .NET MAUI فارسی
Favicon
Xamarin, I Hate U
Favicon
Chart of the Week: Creating a .NET MAUI Column Chart to Visualize Yearly Box Office Data
Favicon
Create and Validate a Login Form in .NET MAUI
Favicon
Elevate Your App’s User Experience with the New .NET MAUI Shimmer Control
Favicon
Introducing the New .NET MAUI Masked Entry Control
Favicon
What’s New in 2023 Volume 1: .NET MAUI Charts

Featured ones: