vue如何写一个宫格

vue如何写一个宫格

实现一个简单的效果,点击哪个div就让他的边框变红

在这里插入图片描述

<div class="test">
            <div
                class="small"
                v-for="(item,index) in list"
                :key="index"
                :class="index===ind?'active':''"   //被激活的div加上active样式
            	@click="cliDiv(item.id)">
            </div>
</div>

data () {
    return {
      list: [{ id: 0 }, { id: 1 }, { id: 2 }, { id: 3 }, { id: 4}],
      ind: 0  //当前的激活索引
    }
},
methods: {
    cliDiv (id) {
      this.ind = id
    }
}

.test{
        width: 1500px;
        height: 400px;
        display: flex;
        .small{
            width: 500px;
            height: 100%;
            border: 2px solid black;
            border-right: none;
            &:last-child{  //less获取最后一个元素要用:last-child
                border-right: 2px solid black;
            }
        }
        .small.active+.small{  // 让激活项的下一个div没有左边框,+表示.active类的下一个.small类
            border-left: none;
        }
        .active{
            border: 2px solid red!important;
        }
    }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值