Vue 标签显示/隐藏的方式对比demo

<!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>
</head>

<body>
    <div id="app">
        <button @click="clearData()">清空数据</button>
        <button @click="recoverData()">恢复数据</button>
        <!-- 1. 通过v-show的方式进行隐藏显示,这样会出现重复多次标签判断 -->
        <ul v-show="items.length>0">
            <li v-for="item in items">{{item.content}}</li>
        </ul>
        <div v-show="items.length>0">v-show方式:共有<span v-text="items.length"></span>条数据</div>
        <!-- 2. 通过添加div进行包裹统一隐藏显示方式,这样会改变原有的DOM模型,div标签会渲染到页面上-->
        <div v-show="items.length>0">
            <ul v-show="items.length>0">
                <li v-for="item in items">{{item.content}}</li>
            </ul>
            <div v-show="items.length>0">通过添加div进行包裹统一隐藏显示方式:共有<span v-text="items.length"></span>条数据</div>
        </div>
        <!-- 3. 通过添加template进行包裹统一隐藏显示方式,这样不会改变原有的DOM模型-->
        <template v-show="items.length>0">
            <ul v-show="items.length>0">
                <li v-for="item in items">{{item.content}}</li>
            </ul>
            <div v-show="items.length>0">通过添加template进行包裹统一隐藏显示方式:共有<span v-text="items.length"></span>条数据</div>
        </template>
    </div>
    <script src="./node_modules/vue/dist/vue.js"></script>
    <script>
        const items = [
            {
                id: 1, //主键id
                content: 'vue.js',//输入内容
                completed: false  //是否完成
            },
            {
                id: 2, //主键id
                content: 'vue.js',//输入内容
                completed: true  //是否完成
            },
            {
                id: 3, //主键id
                content: 'vue.js',//输入内容
                completed: false  //是否完成
            }
        ];
        new Vue({
            el: '#app',
            data: {
                items
            },
            methods: {
                clearData: function () {
                    this.items = [];
                },
                recoverData: function () {
                    this.items = items
                }
            }
        })
    </script>
</body>

</html>

  

posted on 2021-06-05 09:09  水行者  阅读(1264)  评论(0编辑  收藏  举报

导航