IT/development

[Vue.js] checkbox 일괄 체크

알 수 없는 사용자 2023. 9. 24. 13:19
반응형
<!DOCTYPE html>
<html lang="ko">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<body>

    <div id="app">
        <button @click="toggleAllCheckboxes">전체선택</button>
        <br>
        <div v-for="(item, index) in items" :key="index">
            <input type="checkbox" v-model="item.isChecked"> {{ item.name }}
        </div>  
      </div>


    <script src="https://cdn.jsdelivr.net/npm/vue@2.6.14/dist/vue.js"></script>
    <script>
        new Vue({
            el: '#app',     
            data: {
                items: [
                    { name: 'apple', isChecked: false },
                    { name: 'google', isChecked: false },
                    { name: 'microsoft', isChecked: false },
                    { name: 'tesla', isChecked: false }
                ] // 체크박스 항목들
            },      
            methods: {
                toggleAllCheckboxes() { 
                    const areAllChecked = this.items.every(item => item.isChecked);        
                    // 모든 체크박스의 isChecked 상태를 현재 상태와 반대로 설정
                    this.items.forEach(item => (item.isChecked = !areAllChecked));
                }
            }
        });
    </script>    

</body>
</html>

checkbox element를 v-model로 data의 items의 isChecked속성과 양방향 바인딩 시킨 후

전체선택 버튼 클릭 시 items를 순회하며 isChecked를 현재 상태와 반대로 설정

반응형