プログラムを書こう!

実務や自作アプリ開発で習得した役に立つソフトウェア技術情報を発信するブログ

Vuetify3 のダイアログでスクロールさせる

この記事は 2023 年 12 月 16 日に投稿しました。

目次

  1. はじめに
  2. Vuetify3 のダイアログでスクロールさせる
  3. おわりに

1. はじめに

こんにちは、iOS のエディタアプリPWEditorの開発者の二俣です。
今回は業務で使用しているVuetify3のダイアログでスクロールさせる方法についてです。

目次へ

2. Vuetify3のダイアログでスクロールさせる

Vuetify3のダイアログでスクロールさせるには、v-dialogscrollableプロパティを設定し、ダイアログで表示させる内容の高さを固定します。

実装例

<!DOCTYPE html>
<html lang="ja">
  <head>
    <meta charset="UTF-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>Vuetify3 Sample</title>
    <!-- Vue 3のCDN -->
    <script src="https://unpkg.com/vue@3/dist/vue.global.js"></script>
    <!-- Vuetify 3のCDN -->
    <link
      rel="stylesheet"
      href="https://cdn.jsdelivr.net/npm/vuetify@3.3.14/dist/vuetify.min.css"
    />
    <script src="https://cdn.jsdelivr.net/npm/vuetify@3.3.14/dist/vuetify.min.js"></script>
    <!--
      このサイト参考にアイコンのCSSを設定する。
      https://cdnjs.com/libraries/MaterialDesign-Webfont
    -->
    <link
      rel="stylesheet"
      href="https://cdnjs.cloudflare.com/ajax/libs/MaterialDesign-Webfont/7.3.67/css/materialdesignicons.min.css"
    />
  </head>
  <body>
    <div id="app">
      <v-app>
        <v-main>
          <v-container>
            <v-row justify="center">
              <v-col align="center">
                <v-btn @click="dialog = true">ダイアログを開く</v-btn>
                <v-dialog v-model="dialog" width="auto" scrollable>
                  <v-card>
                    <v-card-title>タイトル</v-card-title>
                    <v-card-text style="height: 100px">
                      <li v-for="item in items">{{ item }}</li>
                    </v-card-text>
                    <v-card-actions>
                      <v-btn block @click="dialog = false">閉じる</v-btn>
                    </v-card-actions>
                  </v-card>
                </v-dialog>
              </v-col>
            </v-row>
          </v-container>
        </v-main>
      </v-app>
    </div>

    <script>
      const { createApp, ref } = Vue;
      const { createVuetify } = Vuetify;

      const vuetify = createVuetify();

      const app = createApp({
        setup() {
          const dialog = ref(false);
          const items = [
            "リンゴ",
            "バナナ",
            "オレンジ",
            "ブドウ",
            "なし",
            "いちご",
          ];
          return {
            dialog,
            items,
          };
        },
      });
      app.use(vuetify).mount("#app");
    </script>
  </body>
</html>

実行結果

スクロール前

スクロール後

リファレンス

Vuetify3

v-dialog

scrollableプロパティ

目次へ

3. おわりに

scrollableは、ダイアログにたくさんの行を表示させる場合に使用できると思います。

紹介している一部の記事のコードはGitlabで公開しています。
興味のある方は覗いてみてください。

目次へ


私が勤務しているニューラルでは、主に組み込み系ソフトの開発を行っております。
弊社製品のハイブリッド OS Bi-OSは高い技術力を評価されており、特に制御系や通信系を得意としています。
私自身はiOS モバイルアプリウィンドウズアプリを得意としております。
ソフトウェア開発に関して相談などございましたら、お気軽にご連絡ください。

また一緒に働きたい技術者の方も随時募集中です。
興味がありましたらご連絡ください。

EMAIL : info-nr@newral.co.jp / m-futamata@newral.co.jp
TEL : 042-523-3663
FAX : 042-540-1688

目次へ