20
18

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.

【vue-js-modal】を使ってNuxt.js(vue.js)でモーダルを実装してみた

Last updated at Posted at 2020-02-17

vue-js-modal】は簡単にモーダルウィンドウを実装できるコンポーネントです。
Nuxt.jsでの使い方をまとめました。
イメージは下記の感じです。
lightbox.gif

まずは【vue-js-modal】インストールします。

npm install vue-js-modal --save

Nuxt.jsのディレクトリ構成は下記のようになっています。
nuxt.JPG

pluginsディレクトリにファイルを作成し【vue-js-modal】をインポートします。

今回はmain.jsと言うファイルを作成しました。

├── plugin
│   ├── main.js
main.js
import Vue from 'vue'
import VModal from 'vue-js-modal'

Vue.use(VModal)

次にnuxt.config.jsを編集していきます。

nuxt.config.js
export default {
  plugins: [
    { src: '~/plugins/main.js'}
  ],
}

これで【vue-js-modal】が使用可能になりました。あとは使いたいコンポーネントで使用していきます。

<template>
 <div>
   <button @click="show">クリックする</button>

   <modal name="modal-content">
      <p>モーダルウィンドウで表示されるコンテンツ</p>
   </modal>
 </div>
</template>

<script>
export default {
  methods: {
    show() {
      this.$modal.show("modal-content");
    },
    hide() {
      this.$modal.hide("modal-content");
    }
  }
};
</script>

this.$modal.show()がモーダルウィンドウを開くメソッド、
this.$modal.hide()がモーダルウィンドウを閉じるメソッドになっています。

これだけでモーダルウィンドウができちゃいます。
【vue-js-modal】にはオプションも複数あり、モーダルウィンドウに動きなども追加できます。

例えば下記のような感じです。

   <modal name="modal-content" width="80%" height="auto" :scrollable="true" :draggable="true">
      <p>モーダルウィンドウで表示されるコンテンツ</p>
   </modal>

横幅を指定したり、スクロールバーの有無やモーダルウィンドウをドラッグ可能にすることもできます。

詳しいオプションの種類は下記に記載されています。

vue-js-modal

##最後に

今回はvue.jsで簡単にモーダルウィンドウが実装できる【vue-js-modal】を使ってみました。
ちょうどポートフォリオサイトをNuxt.jsで作っており、作品の紹介などでモーダルウィンドウを実装したかったので・・・
オプションも豊富なので、かなり便利でした。

lightbox.gif

20
18
0

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
20
18

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?