Blazor:是否有一种方式在代码中动态实例化组件并导航到该组件?
创始人
2024-12-22 12:00:16
0

是的,可以通过调用NavigationManager.NavigateTo(uri)方法来与动态实例化的组件进行导航。可以将组件的路由路径作为uri进行导航。

下面是一个简单的示例,演示如何动态实例化组件并导航到该组件。

在Blazor应用程序中,首先创建一个动态组件。可以使用@dynamicComponent.CreateComponent()方法来动态实例化组件。

@inject IComponentService dynamicComponent



@code {
  private RenderFragment myComponent;

  protected override async Task OnInitializedAsync() {
    myComponent = dynamicComponent.CreateComponent(new Dictionary()
    {
        { "Parameter1", "Value1" },
        { "Parameter2", 123 }
    });
  }

  private void NavigateToComponent()
  {
    NavigationManager.NavigateTo("/mycomponent");
  }
}

在上面的代码中,我们先在OnInitializedAsync方法中使用dynamicComponent.CreateComponent()方法来实例化一个名为MyComponent的组件,并将一些参数传递给该组件。我们还为 myComponent 变量设置了一个 RenderFragment,这个变量将在 NavigateToComponent 方法中使用。

现在,您可以在按钮的_click事件中,使用NavigationManager.NavigateTo()方法来导航到动态创建的组件。在这个例子中,我们将导航到/mycomponent路径,这是 MyComponent 组件的路由路径。

要确保该组件在组件映射中具有路由路径。在Startup.cs文件中添加以下代码:

app.UseEndpoints(endpoints =>
{
    endpoints.MapRazorPages();
    endpoints.MapControllers();
    endpoints.MapBlazorHub();
    endpoints.MapFallbackToPage("/_Host");

    endpoints.MapBlazorComponent("/mycomponent");
});

现在,当用户单击“Navigate to Component”按钮时,将触发NavigateToComponent方法,并在应用程序中导航到动态创建的MyComponent组件。

相关内容

热门资讯

这一问题亟待解决!新鸿狐辅助软... 这一问题亟待解决!新鸿狐辅助软件是真的吗,奇迹思维辅助(透视)app-一贯存在有挂1、让任何用户在无...
无独有偶!微信小程序微乐破解器... 无独有偶!微信小程序微乐破解器2024,蛮王大厅辅助教程(透视)攻略-切实是真的挂1、下载好微信小程...
随着!微乐家乡小程序脚本,同城... 随着!微乐家乡小程序脚本,同城游辅助工具(透视)工具-原来真的有挂1、微乐家乡小程序脚本公共底牌简单...
推出新举措!广东雀神智能插件安... 推出新举措!广东雀神智能插件安装免费,好友赣南脚本插件(透视)方法-好像是真的挂1、操作简单,无需广...
做出回应!新518互游插件下载... 做出回应!新518互游插件下载,川娱竞技辅助(透视)挂-确实存在有挂新518互游插件下载脚本下载中分...
有消息称!广东雀神智能插件免费... 有消息称!广东雀神智能插件免费,新畅游互娱辅助(透视)app-原来是真的挂该软件可以轻松地帮助玩家将...
出乎意料的是!微信小程序微乐陕... 出乎意料的是!微信小程序微乐陕西挖坑辅助,新上游拼十辅助(透视)脚本-竟然真的是有挂1、完成微信小程...
现就发布提示!大当家辅助脚本下... 现就发布提示!大当家辅助脚本下载,邯郸胡乐挂(透视)工具-果然真的有挂1、这是跨平台的大当家辅助脚本...
日前!拱趴大菠萝技巧,传送屋激... 日前!拱趴大菠萝技巧,传送屋激k有没有挂(透视)软件-本来有挂1、传送屋激k有没有挂辅助器安装包、传...
长期以来!wepoker辅助器... 长期以来!wepoker辅助器免费,越乡游辅助软件(透视)挂-竟然真的有挂1、wepoker辅助器免...