@page "/" @if (MyList != null && MyList.Count > 0) { @foreach (var item in MyList) { <li>@item</li> } } @using System; @using System.Collections.Generic; @using System.Linq; @using System.Threading; @using System.Threading.Tasks; @code { static int counter; private Dictionary<Guid, List<string>> MyList { get; set; } private Timer Timer { get; set; } // A simple lock to make sure that multiple refreshes don't overlap private bool _isRefreshing; protected override async Task OnInitializedAsync() { await UpdateMyList(); // the initial loading of the list await base.OnInitializedAsync(); Timer = new Timer(async _ => { await RefreshList(); }, null, 0, 100); } private async Task UpdateMyList() { _isRefreshing = true; MyList = await ServiceGetItemsMock(); // external service to get list contents _isRefreshing = false; } private async Task RefreshList() { if (!_isRefreshing) { await UpdateMyList(); await InvokeAsync(StateHasChanged); } } private async Task<Dictionary<Guid, List<string>>> ServiceGetItemsMock() { await Task.Delay(1000); Dictionary<Guid, List<string>> dictionary = new Dictionary<Guid, List<string>>(); for (int i = 0; i < counter+2; i++) { List<string> list = new List<string>(); for (int x = 0; x < 10; x++) { list.Add($"item - {x}"); } dictionary.Add(Guid.NewGuid(), list); } counter++; return dictionary; } }
namespace BlazorFiddleProject { using Microsoft.AspNetCore.Components.Builder; using Microsoft.Extensions.DependencyInjection; public class Startup { public void ConfigureServices(IServiceCollection services) { } public void Configure(IComponentsApplicationBuilder app) { app.AddComponent<App>("app"); } } }
<!DOCTYPE html> <html> <head> <meta charset="utf-8"/> <meta name="viewport" content="width=device-width"> <title>BlazorFiddleProject</title> <link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/bootstrap/4.3.1/css/bootstrap.min.css" integrity="sha384-ggOyR0iXCbMQv3Xipma34MD+dH/1fQ784/j6cY/iJTQUOhcWr7x9JvoRxT2MZw1T" crossorigin="anonymous"> <script src="_content/MatBlazor/dist/matBlazor.js"></script> <style> app { } </style> <script type="text/javascript"> </script> </head> <body> <app>Loading...</app> <script src="_framework/blazor.webassembly.js"></script> <script src="https://code.jquery.com/jquery-3.3.1.slim.min.js" integrity="sha384-q8i/X+965DzO0rT7abK41JStQIAqVgRVzpbzo5smXKp4YfRvH+8abtTE1Pi6jizo" crossorigin="anonymous"></script> <script src="https://cdnjs.cloudflare.com/ajax/libs/popper.js/1.14.7/umd/popper.min.js" integrity="sha384-UO2eT0CpHqdSJQ6hJty5KVphtPhzWj9WO1clHTMGa3JDZwrnQq4sF86dIHNDz0W1" crossorigin="anonymous"></script> <script src="https://stackpath.bootstrapcdn.com/bootstrap/4.3.1/js/bootstrap.min.js" integrity="sha384-JjSmVgyd0p3pXB1rRibZUAYoIIy6OrQ6VrjIEaFf/nJGzIxFDsf4x0xIM+B07jRM" crossorigin="anonymous"></script> </body> </html>

Add component

BlazorFiddle was updated from Blazor 0.7 to .NET 6.0. Your old source code could not work. You need to upgrade to latest.