39
36

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 3 years have passed since last update.

Blazorでコードビハインドでロジックとビューを分離して記述する

Last updated at Posted at 2019-11-24

概要

Blazorのコンポーネントでロジックとビューを分離して記載する方法のメモ。

2020/05/27: Partialクラスによる分離方法を追記しました。
2020/08/12: Partialクラスによるクラス継承を追記しました。

よくある記載例

Blazorのサンプルコードの多くは、下記のようにrazorファイルの中にHTML要素とバインドするC#コードを合わせて記載しています。

counter.razor
@page "/counter"

<h1>Counter</h1>

<p>Current count: @currentCount</p>

<button class="btn btn-primary" @onclick="IncrementCount">Click me</button>

@code {
    private int currentCount = 0;

    private void IncrementCount()
    {
        currentCount++;
    }
}

このような手法とは別に、razorコンポーネントとC#コードを分離して記載するコードビハインドといった記載も可能です。今回はその方法を紹介します。

コードビハインドでの記載方法

モデル(C#コード)

まずは元となるC#側のコードを作成します。

CounterModel.cs
    public class CounterModel : ComponentBase
    {
        public int CurrentCount { get; private set; }

        public void IncrementCount()
        {
            CurrentCount++;
        }
    }

分離しない場合の変更点としては下記になります。

  • ComponentBaseクラスを継承したクラスとする。(Microsoft.AspNetCore.Components)
  • ビューからバインドする変数及び関数をprivateからpublicにする。

ビュー(razorコンポーネント)

次にrazorコンポーネント側を作成します。

Counter.razor
@page "/counter"
@inherits CounterModel

<h1>Counter</h1>

<p>Current count: @CurrentCount</p>

<button class="btn btn-primary" @onclick="IncrementCount">Click me</button>

分離しない場合のrazorコンポーネントとの違いは下記になります。

  • C#コードの代わりにデータバインドするモデルクラス名をinheritsで記載する。

DIの方法

Inject属性を付与したプロパティを使用することで依存性の注入が可能になります。
(具体的なクラスの指定は通常通りStarup.csから指定する。)

CounterModel.cs
    public class CounterModel : ComponentBase
    {
        [Inject]
        protected IDataAccess DataRepository { get; set; }

        public int CurrentCount { get; private set; }

        public void IncrementCount()
        {
            CurrentCount++;
        }
    }

Partialクラスによる分離 (2020/05/27追記)

現在のBlazorでは上記の方法とは別に分離が可能になっています。
raozrファイルと対になるようにcsのファイルを作成するだけです。

Counter.razor
Counter.razor.cs(追加)

razor側は、codeブロックを除いたものを記載します。

Counter.razor
@page "/counter"

<h1>Counter</h1>

<p>Current count: @currentCount</p>

<button class="btn btn-primary" @onclick="IncrementCount">Click me</button>

C#コード側は、クラスをpartialクラスにする必要があります。
それ以外はrazor側に書いていた場合と同じように記載できます。
(変数やメソッドはprivateで対応可能)

Counter.razor.cs

    public partial class Counter
    {
        private int currentCount = 0;

        private void IncrementCount()
        {
            currentCount++;
        }
    }

Partialクラスによる継承 (2020/08/12追記)

基底のクラスを作り、継承させたい場合には下記の2つの対応が必要です。

  • razor側はinheritsで継承
  • cs側はクラスを継承
Counter.razor
@page "/counter"
@inherits ComponentBase

<h1>Counter</h1>

<p>Current count: @currentCount</p>

<button class="btn btn-primary" @onclick="IncrementCount">Click me</button>
Counter.razor.cs

    public partial class Counter : ComponentBase
    {
        private int currentCount = 0;

        private void IncrementCount()
        {
            currentCount++;
        }
    }

まとめ

簡単にですが、Blazorにおけるコードビハインドの方法を紹介しました。
ロジックとビューを分離することで、下記のようなメリットなどが得られます。

  • ロジックに対するUnitTestの記載が可能
  • 基底のコンポーネントクラスの作成などによる共通処理の作成

参考資料

https://www.telerik.com/blogs/using-a-code-behind-approach-to-blazor-components
https://docs.microsoft.com/ja-jp/aspnet/core/blazor/dependency-injection?view=aspnetcore-3.0
https://gunnarpeipman.com/blazor-code-behind/

39
36
3

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
39
36

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?