Vue.js v-onとv-showを使って要素の表示・非表示を切り替えてみよう

皆さんこんにちは、サーバーサイドエンジニアの大川です。今回はv-onとv-showのディレクティブを使って仮想DOMの要素を表示非表示を切り替えてみたいと思います!それでは行ってみましょう!

やること

v-on、v-showディレクティブを用いて「アンテク」の文字列の表示非表示を切り替えてみる。

準備

下記の内容をindex.htmlファイルを作成して記載し、保存します。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <link rel="stylesheet" href="css/app.css">
    <script src="https://cdn.jsdelivr.net/npm/vue@2.*/dist/vue.js"></script>
</head>
<body>
    <div id="app">

    </div>
    <script>
        let app = new Vue({
            el: '#app',
            data() {
                return {

                }
            },
        })
    </script>
</body>
</html>

方法

下記の様に記載をして当該のファイルをブラウザで開いてみましょう。

<!DOCTYPE html>
<html lang="ja">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <script src="https://cdn.jsdelivr.net/npm/vue@2.*/dist/vue.js"></script>
</head>
<body>
    <div id="app">
        <button @click="viewChange()">表示切り替え</button>
        <div v-show="isShow">
            アンテク
        </div>
    </div>
    <script>
        let app = new Vue({
            el: '#app',
            data() {
                return {
                    isShow: false,
                }
            },
            methods: {
                viewChange () {
                    this.isShow = !this.isShow;
                }
            }
        })
    </script>
</body>
</html>

下記のように「表示切り替え」ボタンをクリックすると「アンテク」の文字が表示されたり表示が消えたりすると思います!

また、定義されているviewChange()関数ですが、このレベルの処理ならv-onに直接記載しても良いかもしれません!下記のように書き換えても同じ挙動をします!

<!DOCTYPE html>
<html lang="ja">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <script src="https://cdn.jsdelivr.net/npm/vue@2.*/dist/vue.js"></script>
</head>
<body>
    <div id="app">
        <button @click="isShow = !isShow">表示切り替え</button>
        <div v-show="isShow">
            アンテク
        </div>
    </div>
    <script>
        let app = new Vue({
            el: '#app',
            data() {
                return {
                    isShow: false,
                }
            },
        })
    </script>
</body>

TAGS使用タグ一覧