Redirecting in blazor with parameter

前端 未结 2 1159
粉色の甜心
粉色の甜心 2020-12-20 14:50

Hello how can you redirect to another page in Blazor with a parameter?

@page \"/auth\"
@using Microsoft.AspNetCore.Blazor.Services;
@inject Auth         


        
相关标签:
2条回答
  • 2020-12-20 15:08

    You can only pass parameters in the URL at present.

    So, if your home component was expecting [Parameter] string Name you would need to provide a URL of /home/fred and fred would be passed into the Name parameter of the home component.

    If you are looking to pass more complex data then you would have to look at doing it via some kind of service.

    Here is the link to the official docs on routing parameters: https://blazor.net/docs/routing.html#route-parameters

    0 讨论(0)
  • 2020-12-20 15:11

    Do this:

    • Create a home.cshtml file page like this: Note that two @page directive are employed since optional parameters are not supported yet. The first permits navigation to the component without a parameter. The second @page directive takes the {username} route parameter and assigns the value to the Username property.

    Pages/home.cshtml

    @page "/home"
    @page "/home/{username}"
    
    <h1>@Username is authenticated!</h1>
    
    @functions {
        // Define a property to contain the parameter passed from the auth page
        [Parameter]
        private string Username { get; set; };
    }
    
    • Do this in your auth.cshtml
        @functions{
    
            public string Username { get; set; }
            public string url = "/home";
    
            public async Task AuthAsync()
            {
                var ticket=await this.auth.AuthenticateAsync(Username);
                // Attach the parameter to the url
                urihelper.NavigateTo(url + "/" + Username); 
            }
        }
    

    Hope this helps...

    0 讨论(0)
提交回复
热议问题