54 lines
1.3 KiB
Plaintext
54 lines
1.3 KiB
Plaintext
@using Microsoft.AspNetCore.Blazor.Browser.Services.Temporary
|
|
@inject HttpClient Http
|
|
|
|
<h1>Weather forecast</h1>
|
|
|
|
<p>This component demonstrates fetching data from the server.</p>
|
|
|
|
@if (forecasts == null)
|
|
{
|
|
<p><em>Loading...</em></p>
|
|
}
|
|
else
|
|
{
|
|
<table class='table'>
|
|
<thead>
|
|
<tr>
|
|
<th>Date</th>
|
|
<th>Temp. (C)</th>
|
|
<th>Temp. (F)</th>
|
|
<th>Summary</th>
|
|
</tr>
|
|
</thead>
|
|
<tbody>
|
|
@foreach (var forecast in forecasts)
|
|
{
|
|
<tr>
|
|
<td>@forecast.DateFormatted</td>
|
|
<td>@forecast.TemperatureC</td>
|
|
<td>@forecast.TemperatureF</td>
|
|
<td>@forecast.Summary</td>
|
|
</tr>
|
|
}
|
|
</tbody>
|
|
</table>
|
|
}
|
|
|
|
@functions {
|
|
WeatherForecast[] forecasts;
|
|
|
|
protected override async Task OnInitAsync()
|
|
{
|
|
var json = await Http.GetStringAsync("/sample-data/weather.json");
|
|
forecasts = Microsoft.AspNetCore.Blazor.Json.Deserialize<WeatherForecast[]>(json);
|
|
}
|
|
|
|
class WeatherForecast
|
|
{
|
|
public string DateFormatted { get; set; }
|
|
public int TemperatureC { get; set; }
|
|
public int TemperatureF { get; set; }
|
|
public string Summary { get; set; }
|
|
}
|
|
}
|