Blazor WebAssembly アプリケーションを作成する - 何もしない Blazor WebAssembly アプリケーションの実行

非常にシンプルな、何もしないBlazor WebAssemblyアプリケーションを作成する手順を紹介します。

手順

新しいプロジェクトの作成ダイアログを表示します。プロジェクトテンプレートから "Blazor WebAssembly アプリが空です" の項目をクリックして選択します。 [次へ]ボタンをクリックします。
Blazor WebAssembly アプリケーションを作成する - 何もしない Blazor WebAssembly アプリケーションの実行:画像1

プロジェクト名を設定します。[次へ]ボタンをクリックします。
Blazor WebAssembly アプリケーションを作成する - 何もしない Blazor WebAssembly アプリケーションの実行:画像2

使用する.NET Framework、各種オプションを設定します。設定ができたら[作成]ボタンをクリックします。
Blazor WebAssembly アプリケーションを作成する - 何もしない Blazor WebAssembly アプリケーションの実行:画像3

Blazor WebAssembly アプリケーションのプロジェクトが作成覚ます。
Blazor WebAssembly アプリケーションを作成する - 何もしない Blazor WebAssembly アプリケーションの実行:画像4

ソリューションエクスプローラーを表示します。作成されたファイルの一覧は下図です。
Blazor WebAssembly アプリケーションを作成する - 何もしない Blazor WebAssembly アプリケーションの実行:画像5

ファイル

作成される主要なファイルの内容です。

wwwroot\index.html
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="utf-8" />
    <title>BlankBlazorApp</title>
    <base href="/" />
    <link href="css/app.css" rel="stylesheet" />
    
    <!-- If you add any scoped CSS files, uncomment the following to load them
    <link href="BlankBlazorApp.styles.css" rel="stylesheet" /> -->
</head>

<body>
    <div id="app">Loading...</div>

    <div id="blazor-error-ui">
        An unhandled error has occurred.
        <a href="" class="reload">Reload</a>
        <a class="dismiss">🗙</a>
    </div>
    <script src="_framework/blazor.webassembly.js"></script>
</body>

</html>

wwwroot\css\app.css
h1:focus {
    outline: none;
}

#blazor-error-ui {
    background: lightyellow;
    bottom: 0;
    box-shadow: 0 -1px 2px rgba(0, 0, 0, 0.2);
    display: none;
    left: 0;
    padding: 0.6rem 1.25rem 0.7rem 1.25rem;
    position: fixed;
    width: 100%;
    z-index: 1000;
}

    #blazor-error-ui .dismiss {
        cursor: pointer;
        position: absolute;
        right: 0.75rem;
        top: 0.5rem;
    }

.blazor-error-boundary {
    background: url() no-repeat 1rem/1.8rem, #b32121;
    padding: 1rem 1rem 1rem 3.7rem;
    color: white;
}

    .blazor-error-boundary::after {
        content: "An error has occurred."
    }

Pages\index.razor
@page "/"

<h1>Hello, world!</h1>

_Imports.razor
@using System.Net.Http
@using System.Net.Http.Json
@using Microsoft.AspNetCore.Components.Routing
@using Microsoft.AspNetCore.Components.Web
@using Microsoft.AspNetCore.Components.WebAssembly.Http
@using Microsoft.JSInterop
@using BlankBlazorApp

App.razor
<Router AppAssembly="@typeof(App).Assembly">
    <Found Context="routeData">
        <RouteView RouteData="@routeData" DefaultLayout="@typeof(MainLayout)" />
        <FocusOnNavigate RouteData="@routeData" Selector="h1" />
    </Found>
    <NotFound>
        <PageTitle>Not found</PageTitle>
        <LayoutView Layout="@typeof(MainLayout)">
            <p role="alert">Sorry, there's nothing at this address.</p>
        </LayoutView>
    </NotFound>
</Router>

MainLayout.razor
@inherits LayoutComponentBase

<main>
    @Body
</main>

Program.cs
using BlankBlazorApp;
using Microsoft.AspNetCore.Components.Web;
using Microsoft.AspNetCore.Components.WebAssembly.Hosting;

var builder = WebAssemblyHostBuilder.CreateDefault(args);
builder.RootComponents.Add<App>("#app");
builder.RootComponents.Add<HeadOutlet>("head::after");

builder.Services.AddScoped(sp => new HttpClient { BaseAddress = new Uri(builder.HostEnvironment.BaseAddress) });

await builder.Build().RunAsync();

実行結果

プロジェクトを実行します。Hello, World のページが表示されます。

Blazor WebAssembly アプリケーションを作成する - 何もしない Blazor WebAssembly アプリケーションの実行:画像6

AuthorPortraitAlt
著者
iPentecのメインプログラマー
C#, ASP.NET の開発がメイン、少し前まではDelphiを愛用
作成日: 2024-06-29
Copyright © 1995–2025 iPentec all rights reserverd.