問題描述
我開始使用 Blazor
服務器端,但我沒有得到正確的路由.我不明白 _host.cshtml
中需要 base
標記.如果我仍然需要在每個 Blazor 組件中添加 base
url,例如:我想要一個 /app/
的基地址和 @page<值為
"/counter"
的示例 Counter
的/code> 指令不會編譯"為 "/app/counter"
.我必須將 @page
設置為 "/app/counter"
這很有意義,但這意味著 _host 中的
沒用...base
標記.cshtml
我在這里做錯了什么?
<base href='' >
是一個
I am getting started with Blazor
server-side and I don't get the routing right. I don't understand the need for the base
tag in _host.cshtml
. If I still have to add the base
url in every Blazor component, for example: I want to have a base address of /app/
and the @page
directive for the example Counter
with a value of "/counter"
does not "compile" to "/app/counter"
. I have to set the @page
to "/app/counter"
which makes sense but that means that the base
Tag in _host.cshtml
is useless...
What am I getting wrong here?
The <base href='' >
is a client side technology that specifies the base URL for all relative URLs in current document. Many SPA frameworks , e.g. Angular, will use this element.
I have to set the @page to "/app/counter"
Actually, you don't have to and should never do that. One of the most important advantages when using <base>
is that it allows us to create an app without letting the components know about the base url.
Assuming you've changed the base href
from '/' to '/app/', and also changed the other relative urls:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8" />
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
<title>BlazorApp</title>
<base href="/app/" />
<link rel="stylesheet" href="/css/bootstrap/bootstrap.min.css" />
<link href="/css/site.css" rel="stylesheet" />
</head>
<body>
<app>
@(await Html.RenderComponentAsync<App>(RenderMode.ServerPrerendered))
</app>
<script src="/_framework/blazor.server.js"></script>
</body>
</html>
Don't forget to prepend the default Blazor
Hub url with a /app/
:
app.UseEndpoints(endpoints => { endpoints.MapBlazorHub("/app/_blazor"); endpoints.MapFallbackToPage("/_Host"); });
That's all. There's no need to change the routes from @page "/counter"
to @page "/app/counter"
at all.
Demo
Here's a demo that we don't change the @page
routes for components:
這篇關于.razor 文件中的 Blazor 基本標記和 @page 指令的文章就介紹到這了,希望我們推薦的答案對大家有所幫助,也希望大家多多支持html5模板網!