不在首次导航到URL时渲染Webassembly应用程序的任何内容

huangapple go评论57阅读模式
英文:

Doesn't render anything of the Webassembly application when navigating the first time to the url

问题

抱歉,由于你要求不提供代码的翻译,我将只为你翻译非代码部分的内容。

你提到了关于Blazor WebAssembly应用程序预呈现以改善SEO的问题。你实施了这个解决方案,并提到了一些问题:

  1. 当首次导航到URL时,WebAssembly应用程序不渲染任何内容。
  2. Lighthouse给出了关于href需要链接到适当目的地的建议,但这些目的地是使用Fluxor创建的。

关于这些问题,你还提到了是否需要添加robots.txt文件以及放置它的位置。

如果你有关于这些问题的具体问题或需要更多帮助,请随时提问。

英文:

I don't know a lot of Blazor but I do have a problem that I think a lot of us are trying to solve.

I have a Blazor Webassembly application that I'm trying to prerender for improving the SEO. I implemented the following solution: https://andrewlock.net/enabling-prerendering-for-blazor-webassembly-apps/

So I have a Host and a Webassembly application. This application just shows a list of available jobs with the following information: jobtitle, region and tech stack. When you click on the card which is wrapped around an a tag, you navigate to the detail page of the job. In the Webassembly application I'm using Fluxor for store state. So this is already my first problem. It doesn't render anything of the Webassembly application when navigating the first time to the url. Only the things I placed in the following:

<div id="blazor-error-ui">
	<div class="header">
   		<h1>Jobs</h1>
   		<h2>Find a job!</h2>
	</div>
	An unhandled error has occurred.
    	<a href="" class="reload">Reload</a>
    	<a class="dismiss">x</a>
</div>

As you can see in the network tab:

networkTab

My _Host.cshtml body looks like this:

<body>
    <div id="app">
        <component type="typeof(Craxit.Jobs.Blazor.App)" render-mode="WebAssemblyPrerendered" />
    </div>

    <div id="blazor-error-ui">
        <div class="header">
            <h1>Jobs</h1>
            <h2>Find a job!</h2>
        </div>
        An unhandled error has occurred.
        <a href="" class="reload">Reload</a>
        <a class="dismiss">🗙</a>
    </div>
    <script src="_framework/blazor.webassembly.js"></script>
    <script src="_content/MudBlazor/MudBlazor.min.js"></script>
    <script src="js/mask.js"></script>
    <script src="https://www.google.com/recaptcha/api.js"></script>
    <script src="js/googleRecaptcha.js"></script>
    <script>
        function scrollIntoView(elementId) {
            var elem = document.getElementById(elementId);
            if (elem) {
                elem.scrollIntoView({ behavior: 'smooth' });
                window.location.hash = elementId;
            }
        }
    </script>

    <!-- Global site tag (gtag.js) - Google Analytics -->
    <script async src="https://www.googletagmanager.com/gtag/js?id=UA-73108595-3"></script>
    <script>
        window.dataLayer = window.dataLayer || [];
        function gtag() { dataLayer.push(arguments); }
        gtag('js', new Date());
        gtag('config', 'UA-73108595-3');
    </script>
    <script src="https://cdn.jsdelivr.net/npm/cookieconsent@3/build/cookieconsent.min.js" data-cfasync="false"></script>
    <script src="js/ShowCookieConsent.js"></script>
</body>

And in my webassembly application I have the following:

<Fluxor.Blazor.Web.StoreInitializer />

@if(GeneralState.Value.IsPermanent is not null)
{
    <Router AppAssembly="@typeof(App).Assembly" PreferExactMatches="@true">
        <Found Context="routeData">
            <RouteView RouteData="@routeData" DefaultLayout="@typeof(MainLayout)" />
        </Found>
        <NotFound>
            <LayoutView Layout="@typeof(MainLayout)">
                <p>Sorry, there's nothing at this address.</p>
            </LayoutView>
        </NotFound>
    </Router>
}

Where in the code I load the jobs and place them in the store:

@code {        
    protected override void OnInitialized()
    {
        Dispatcher.Dispatch(new LoadContractFilterAction());
        base.OnInitialized();
    }
}

When also looking to the url with Lighthouse I get the following mention:

ResponseLighthouse

But I don't added a robot.txt file? Do I need to add it? Any idea where I can place it? The structure of my application is:

  • Client with the App that's rendered in the Server -> so I do think that the wwwroot is not used anymore? This clients contains the complete setup of the application.
  • Host with a _Host.cshtml -> place it here? This only refers to the client.

Also in the response of the ligthouse I saw that he says that the href needs to be linked to appropriate destinations. But this destinations are created with fluxor, so is it possible because of that?

Kind regards and thank you in advance!

答案1

得分: 0

Blazor WASM 不友好于 SEO。但是,您可以通过使用组件标签助手向您的页面动态添加meta标签(以及其他head元素)来控制 ASP.NET Core Blazor 应用程序中的<head>内容

在 Program.cs 中配置了 HeadOutlet

var builder = WebAssemblyHostBuilder.CreateDefault(args);
builder.RootComponents.Add&lt;App&gt;(&quot;#app&quot;);
builder.RootComponents.Add&lt;HeadOutlet&gt;(&quot;head::after&quot;);

HeadOutlet 组件呈现由 PageTitleHeadContent 组件提供的内容。如果您遵循预呈现和集成 ASP.NET Core Razor 组件的说明,将会配置HeadOutlet组件如下:

&lt;component type=&quot;typeof(HeadOutlet)&quot; render-mode=&quot;WebAssemblyPrerendered&quot; /&gt;
英文:

Blazor WASM is not SEO friendly. But you can Control <head> content in ASP.NET Core Blazor apps by adding dynamic meta tags (and other head elements) to your pages via Component Tag Helper, HeadContent, and HeadOutlet:

There is HeadOutlet configured in Program.cs:

var builder = WebAssemblyHostBuilder.CreateDefault(args);
builder.RootComponents.Add&lt;App&gt;(&quot;#app&quot;);
builder.RootComponents.Add&lt;HeadOutlet&gt;(&quot;head::after&quot;);

The HeadOutlet component renders content provided by PageTitle and HeadContent components. If you follow Prerender and integrate ASP.NET Core Razor components instructions you will get HeadOutlet component configured like this:

&lt;component type=&quot;typeof(HeadOutlet)&quot; render-mode=&quot;WebAssemblyPrerendered&quot; /&gt;

huangapple
  • 本文由 发表于 2023年2月23日 19:24:53
  • 转载请务必保留本文链接:https://go.coder-hub.com/75544169.html
匿名

发表评论

匿名网友

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen:

确定