How to set @ref for child components in Grid > GridColumn template?
How to set @ref for child components in a Sf Grid with GridColumn template?
https://www.syncfusion.com/faq/blazor/components/how-to-set-ref-for-dynamically-generated-elements
But this doesn't seem to work when using another Sf Component in a GridColumn Template, eg:
<SfGrid>
<GridColumns>
<GridColumn Field="State" HeaderText="State" Width="90">
<Template>
@{
var myObj = (context as MyCustomObject);
<div>
<SfProgressButton @ref="@SfRefreshButtons[myObj.Id]" CssClass="e-round e-small" IconCss="mdi mdi-refresh-circle" OnClick="@(() => OnRefreshClick(myObj.Id))">
<ProgressButtonSpinSettings Position="SpinPosition.Center"></ProgressButtonSpinSettings>
<ProgressButtonAnimationSettings Effect="AnimationEffect.ZoomOut"></ProgressButtonAnimationSettings>
</SfProgressButton>
</div>
}
</Template>
</GridColumn>
</GridColumns>
<SfGrid>
SIGN IN To post a reply.
3 Replies
1 reply marked as answer
VN
Vignesh Natarajan
Syncfusion Team
June 25, 2020 10:16 AM UTC
Hi Davy,
Thanks for contacting Syncfusion support.
Query: “But this doesn't seem to work when using another Sf Component in a GridColumn Template,”
From your query we understand that you are facing difficulties while taking the instance of Child components in Grid. We have prepared a sample using ProgressBar inside the GridColumnTemplate and initialized the instance of the button in code section.
Refer the below code example.
|
@using Syncfusion.Blazor.Grids
@using Syncfusion.Blazor.SplitButtons
<SfGrid DataSource="@Employees">
<GridColumns>
<GridColumn HeaderText="Employee Image" TextAlign="TextAlign.Center" Width="120">
<Template>
@{
var myObj = (context as EmployeeData);
<div>
<SfProgressButton @ref="@SfRefreshButtons[myObj.EmployeeID]" CssClass="e-round e-small" IconCss="mdi mdi-refresh-circle" OnClick="@(() => OnRefreshClick(myObj.EmployeeID))">
<ProgressButtonSpinSettings Position="SpinPosition.Center"></ProgressButtonSpinSettings>
<ProgressButtonAnimationSettings Effect="AnimationEffect.ZoomOut"></ProgressButtonAnimationSettings>
</SfProgressButton>
</div>
}
</Template>
</GridColumn>
</GridColumns>
</SfGrid>
@code{
private Dictionary<int?, SfProgressButton> SfRefreshButtons = new Dictionary<int?, SfProgressButton>();
public void OnRefreshClick(int? val)
{
var a = SfRefreshButtons;
}
|
Refer the below screenshot for your reference
|
|
Kindly get back to us if you have further queries or share more details about your requirement.
Regards,
Vignesh Natarajan
Marked as answer
DA
Davy
June 25, 2020 01:10 PM UTC
Thanks, got it working now.
VN
Vignesh Natarajan
Syncfusion Team
June 26, 2020 04:12 AM UTC
Hi Davy,
Thanks for the update.
We are glad to hear that you have resolved your query using our solution.
Kindly get back to us if you have further queries.
Regards,
Vignesh Natarajan
SIGN IN To post a reply.