【Blazor】 @refを使い方
- @refとは?
- 参照されるコンポーネントを作成
- 作成したコンポーネントを参照する
- 実用的なシナリオ
- 注意点
目次
@refとは?

@refとはBlazorコンポーネントの参照するためのディレクティブのことです。 これを使用することで、親コンポーネントから子コンポーネントのメソッドを呼び出したり、プロパティを変更することができるようになります。
参照されるコンポーネントを作成

まず、参照するための子コンポーネントを作成していきます。 親コンポーネントからUpdateMessageメソッドが呼ばれると、UIのテキストが引数の値に変更される仕組みになっています。
<h3>@Message</h3>
@code {
public string Message { get; set; } = "初期メッセージ";
public void UpdateMessage(string newMessage)
{
Message = newMessage;
// 状態変更後、コンポーネントの再レンダリングをトリガーします
StateHasChanged();
}
}
作成したコンポーネントを参照する

前セクションで作成したコンポーネント(ChildComponent)を使って、コンポーネントを参照します。 以下コード例になります。
@page "/parent"
@using Blazor_Ref.Components;
<ChildComponent @ref="childRef" />
<button @onclick="UpdateChildMessage">子コンポーネントのメッセージを更新</button>
@code {
private ChildComponent? childRef;
private void UpdateChildMessage()
{
childRef?.UpdateMessage("ボタンによるメッセージ更新");
}
}
親コンポーネント内で子コンポーネントであるChildComponentを@refを用いて参照します。 @refには、コンポーネントの変数であるchildRefを指定します。そうすることで、値が共有されます。 ボタンを押したタイミングで、参照した子コンポーネントからUpdateMessageメソッドを呼び出しています。 ボタンをクリックし、メッセージが初期メッセージからボタンによるメッセージ更新へ変更されることを確認してください。
実用的なシナリオ

様々な場面で活用することができますが、次の場面がよく使われそうな気がします。
- フォームのバリデーション
- モーダルダイアログ
注意点

@refで参照したコンポーネントがレンダリングが完了してから、使用するようにしてください。 注意が必要なのは、以下のようなコードです。
@page "/parent"
@using Blazor_Ref.Components;
<ChildComponent @ref="childRef" />
@code {
private ChildComponent? childRef;
protected override void OnInitialized()
{
// 初期化時 childRef はまだ null になっている
childRef.UpdateMessage("新しいメッセージ");
}
protected override void OnAfterRender(bool firstRender)
{
if (firstRender)
{
// OnAfterRenderはレンダリング後の処理なので childRef は null ではありません。
childRef?.UpdateMessage("レンダリング後の更新メッセージ");
}
}
}
OnInitializedメソッドなどの初期化処理などで、レンダリングされていない状態だとnull参照になります。 それに比べて、OnAfterRenderはレンダリング後に行う処理のため、null参照にはなりません。 もし参照したコンポーネントで初期化等が必要な場合は、OnAfterRenderで行うようにします。
@refは便利ですが、使用は最低限に抑え、ロジックはなるべくコンポーネント内で完結するように心がけると、 バグの少ないアプリケーションになると思います。
この本では、Blazorの基本から高度なテクニックまで、実際のプロジェクトに役立つ知識を網羅しています。 初心者から経験者まで、Blazorを扱うすべての開発者にとっての必読書です。 この記事の執筆者も参考にした「Blazor入門」で、あなたのBlazorスキルを飛躍的に向上させませんか?
合わせて読みたい

DOMイベント一覧
この記事では、Blazorで使用可能なDOMイベントに関する包括的なガイドを提供しています。DOM(Document Object Model)はウェブページの内容や構造を表現するための仕組みであり、Blazorを用いることで、さまざまなDOMイベントを効果的に扱うことが可能です。記事は、onabortからonwheelまで、様々なイベントの名前と発生条件を詳細な表形式で紹介しています。これにより、Blazor開発者は適切なイベントを状況に応じて選択し、ウェブページのインタラクティビティを高めることができます。
更新日:2023/09/03

faviconの設定方法
Blazorでのfavicon設定方法を解説。Faviconはサイトの識別アイコンで、複数のブラウザやデバイスに適応する必要がある。RealFaviconGeneratorを利用すれば、一つの画像から必要なすぐれたFaviconを簡単に生成できる。Blazorへの適用手順や、Safariでの反映遅延についても触れられている。
更新日:2023/08/29