SHOEISHA iD

※旧SEメンバーシップ会員の方は、同じ登録情報(メールアドレス&パスワード)でログインいただけます

CodeZine編集部では、現場で活躍するデベロッパーをスターにするためのカンファレンス「Developers Summit」や、エンジニアの生きざまをブーストするためのイベント「Developers Boost」など、さまざまなカンファレンスを企画・運営しています。

【最新Nuxtアップデート解説】Nuxtの変更点まとめ

Vueベースのフレームワーク「Nuxt 4.3」までの大きな変更点──コンポーザブルやコンポーネント

【最新Nuxtアップデート解説】Nuxtの変更点まとめ 第2回

実行を1回に限定できるcallOnce

 次に紹介するのは、処理の実行を1回だけに制限できるcallOnce()コンポーザブルです。

引数アロー関数を1回だけ実行

 callOnce()は、バージョン3.9で導入されたコンポーザブルであり、リスト3のように使います。

[リスト3]no02/once/app/app.vue
<script setup lang="ts">
const timestampState = useState<Date>("appTimestamp");  // (1)
callOnce(
  () => {  // (2)
    timestampState.value = new Date();  // (3)
  }
);
</script>

 リスト3の(2)のように、引数としてアロー関数を定義します。すると、このコンポーネントがサーバサイドでレンダリングされる初回のみ、アロー関数内のコードが実行されます。

 このcallOnce()には、戻り値があるわけではありませんし、ハイドレーションしていない状態を想定しています。そのためアロー関数内のコードとしては、非同期で取得・生成したデータをログに記録したり、ステートに格納したりすることを想定しています。

 リスト3では、(1)で用意したステートのappTimestampに、(3)でその時点での日時データを格納するようにしています。

 すると、このコンポーネントがサーバサイドでレンダリングされたその時点の日時がステートに格納され、それ以降このコンポーネントを何回表示させたとしても、最初に格納した日時データのみ保持し、上書きされることはありません。試しに、appTimestampをさまざまな画面で表示させたとしても、その値は変わりません。

ナビゲーションモードの追加

 このcallOnce()に対して、バージョン3.15で、ナビゲーションモードが追加されました。この機能により、クライアントサイドでのナビゲーションのたびに特定の処理を実行できるようになります。

 ナビゲーションモードを使用するには、リスト4の(1)のように、callOnce()の第2引数オブジェクトのmodeプロパティにnavigationを指定します。

[リスト4]no02/once/app/app.vue
callOnce(
  () => {
    timestampStateNavi.value = new Date();
  },
  { mode: "navigation" }  // (1)
);

 ナビゲーションモードは、以下のように動作します。

  • サーバーサイド:最初のレンダリング時に一度だけ実行されます。
  • クライアントサイド:このオプションを指定すると、クライアントサイドのナビゲーション(例:ページ遷移)が行われるたびに、アロー関数内のコードが実行されます。

 上記の例では、ステートtimestampStateNaviにその時点の日時を格納するコードが記述されています。ナビゲーションモードをnavigationに設定することで、このページへ遷移するたびに、ステートtimestampStateNaviが最新の日時データで上書きされるようになります。

 これにより、アプリケーション内でページ遷移ごとに動的にデータや状態を更新したい場合に、callOnce()をより柔軟に活用できるようになります。

次のページ
日時表示専用コンポーネントであるNuxtTime

この記事は参考になりましたか?

【最新Nuxtアップデート解説】Nuxtの変更点まとめ連載記事一覧
この記事の著者

WINGSプロジェクト 齊藤 新三(サイトウ シンゾウ)

WINGSプロジェクトについて>有限会社 WINGSプロジェクトが運営する、テクニカル執筆コミュニティ(代表 山田祥寛)。主にWeb開発分野の書籍/記事執筆、翻訳、講演等を幅広く手がける。2018年11月時点での登録メンバは55名で、現在も執筆メンバを募集中。興味のある方は、どしどし応募頂きたい。著書記事多数。 RSS X: @WingsPro_info(公式)、@WingsPro_info/wings(メンバーリスト) Facebook <個人紹介>WINGSプロジェクト所属のテクニカルライター。Web系製作会社のシステム部門、SI会社を経てフリーランスとして独立。屋号はSarva(サルヴァ)。HAL大阪の非常勤講師を兼務。

※プロフィールは、執筆時点、または直近の記事の寄稿時点での内容です

山田 祥寛(ヤマダ ヨシヒロ)

静岡県榛原町生まれ。一橋大学経済学部卒業後、NECにてシステム企画業務に携わるが、2003年4月に念願かなってフリーライターに転身。Microsoft MVP for Visual Studio and Development Technologies。執筆コミュニティ「WINGSプロジェクト」代表。主な著書に「独習シリーズ(Java・C#・Python・PHP・Ruby・JSP&サーブレットなど)」「速習シリーズ(ASP.NET Core・Vue.js・React・TypeScript・ECMAScript、Laravelなど)」「改訂3版JavaScript本格入門」「これからはじめるReact実践入門」「はじめてのAndroidアプリ開発 Kotlin編 」他、著書多数

※プロフィールは、執筆時点、または直近の記事の寄稿時点での内容です

この記事は参考になりましたか?

この記事をシェア

CodeZine(コードジン)
https://codezine.jp/article/detail/23622 2026/03/19 08:00

おすすめ

アクセスランキング

アクセスランキング

イベント

CodeZine編集部では、現場で活躍するデベロッパーをスターにするためのカンファレンス「Developers Summit」や、エンジニアの生きざまをブーストするためのイベント「Developers Boost」など、さまざまなカンファレンスを企画・運営しています。

新規会員登録無料のご案内

  • ・全ての過去記事が閲覧できます
  • ・会員限定メルマガを受信できます

メールバックナンバー

アクセスランキング

アクセスランキング