blazor-devexpress-dot-blazor-dot-dxgrid-dot-makecellvisibleasync-x28-system-dot-object-system-dot-string-x29.md
Navigates to the cell bound to the specified data item’s field.
Namespace : DevExpress.Blazor
Assembly : DevExpress.Blazor.v25.2.dll
NuGet Package : DevExpress.Blazor
public Task MakeCellVisibleAsync(
object dataItem,
string fieldName
)
| Name | Type | Description |
|---|---|---|
| dataItem | Object |
A data item.
| | fieldName | String |
A data source field name.
|
| Type | Description |
|---|---|
| Task |
The task that is completed when the cell becomes visible.
|
The Grid uniquely identifies each data cell by the bound data item and associated field. Pass a data item and field name to the MakeDataItemVisibleAsync method to make the corresponding cell visible on screen. Once called, the method performs the following actions:
The MakeDataItemVisibleAsync method does nothing in the following cases:
false (default).The following code snippet adds a button that navigates to the selected cell’s Forecast value:
@inject WeatherForecastService ForecastService
<DxGrid Data="@Data"
@ref="MyGrid"
SelectionMode="GridSelectionMode.Single"
@bind-SelectedDataItem="@SelectedDataItem"
KeyFieldName="Date">
<Columns>
<DxGridSelectionColumn />
<DxGridDataColumn FieldName="Date" DisplayFormat="D" />
<DxGridDataColumn FieldName="TemperatureC" Caption="@("Temp. (\x2103)")" Width="120px" />
<DxGridDataColumn FieldName="TemperatureF" Caption="@("Temp. (\x2109)")" Width="120px" />
<DxGridDataColumn FieldName="Forecast" />
<DxGridDataColumn FieldName="CloudCover" />
</Columns>
<ToolbarTemplate>
<DxToolbar>
<DxToolbarItem Text="Go to Selected Forecast"
Click="@(() => MyGrid.MakeCellVisibleAsync(SelectedDataItem, "Forecast"))" />
</DxToolbar>
</ToolbarTemplate>
</DxGrid>
@code {
IGrid MyGrid;
IEnumerable<WeatherForecast> Data { get; set; }
object SelectedDataItem { get; set; }
protected override void OnInitialized() {
Data = ForecastService.GetForecast();
SelectedDataItem = Data.Last();
}
}
using System;
public class WeatherForecast {
public DateTime Date { get; set; }
public int TemperatureC { get; set; }
public double TemperatureF => Math.Round((TemperatureC * 1.8 + 32), 2);
public string Forecast { get; set; }
public string CloudCover { get; set; }
public bool Precipitation { get; set; }
}
using System;
using System.Collections.Generic;
using System.Linq;
using System.Threading;
using System.Threading.Tasks;
public class WeatherForecastService {
private List<WeatherForecast> Forecast { get; set; }
private static string[] CloudCover = new[] {
"Sunny", "Partly cloudy", "Cloudy", "Storm"
};
Tuple<int, string>[] ConditionsForForecast = new Tuple<int, string>[] {
Tuple.Create( 22 , "Hot"),
Tuple.Create( 13 , "Warm"),
Tuple.Create( 0 , "Cold"),
Tuple.Create( -10 , "Freezing")
};
public WeatherForecastService() {
Forecast = CreateForecast();
}
private List<WeatherForecast> CreateForecast() {
var rng = new Random();
DateTime startDate = DateTime.Now;
return Enumerable.Range(1, 150).Select(index => {
var temperatureC = rng.Next(-10, 30);
return new WeatherForecast {
Date = startDate.AddDays(index),
TemperatureC = temperatureC,
CloudCover = CloudCover[rng.Next(0, 4)],
Precipitation = Convert.ToBoolean(rng.Next(0, 2)),
Forecast = ConditionsForForecast.First(c => c.Item1 <= temperatureC).Item2
};
}).ToList();
}
public IEnumerable<WeatherForecast> GetForecast() {
return Forecast.ToArray();
}
// ...
}
// ...
builder.Services.AddSingleton<WeatherForecastService>();
MakeCellVisibleAsync(Object, String)
See Also
MakeCellVisible(Int32, String)