Vue点击切换class

Vue点击切换多个class

1201653-20180731160017178-1721377808.png

    <template>
        <div class="city">
            <ul>
                <li v-for="(item,index) in items" :class="{'active':item.checked}" @click="isActive(item)">{{item.text}}</li>
            </ul>
        </div>
    </template>
    <script>
    import Vue from 'vue'
    export default{
        data:function() {
            return {
                items:[
                    {text: '静安区'},
                    {text: '宝山区'},
                    {text: '虹口区'},
                    {text: '闵行区'},
                    {text: '普陀区'},
                    {text: '青浦区'},
                    {text: '金山区'},
                    {text: '奉贤区'},
                    {text: '浦东新区'},
                    {text: '长宁区'},
                    {text: '松江区'},
                    {text: '嘉定区'},
                    {text: '杨浦区'},
                    {text: '黄埔区'},
                    {text: '徐汇区'}
                ]
            }
        },
        mounted:function() {
    
        },
        methods: {
            isActive:function(item){
                        //方法1
                if(typeof item.checked == 'undefined') {
                    //全局创建
                    //Vue.set(item,'checked',true);
                    //局部创建
                     this.$set(item,'checked',true);
                    // console.log(item.text)
    
                }else{
                    item.checked = !item.checked;
                }
                        //方法2
                         this.$set(item,'checked',!item.checked);
            }
        }
    }
    </script>
    <style lang='less'>
    .city {
        width: 100%;
        ul {
            display:flex;
            flex-flow: row wrap;
            width: 100%;
            padding: 0 10px;
            box-sizing: border-box;
            text-align: center;
            li {
                display: inline-block;
                width: 23%;
                padding: 5px 0;
                margin: 5px 6px 0 0;
                box-sizing: border-box;
                background: #eee;
            }
            .active {
                background: blue;
                color: #fff;
            }
        }
    }
    </style>

转载于:https://www.cnblogs.com/DCL1314/p/9396359.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值