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>

  


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM