前言
需求场景:移动端/h5/公众号页面,有很多分类,每个分类下展示图片,默认超出两张 出现展开和收起功能。
一、思路
这类功能很常见,其实之前也写过;正常思路都是搞个类似单独的变量去控制分类下图片是展开/收起;但是代码很是累赘,于是就想说能不能用原生的代码去写。
接口返回的数据格式大致如下:
list =
[
{
title: '标题一',
id:'1',
imgList:[
'img1','img2',...
]
},
{
title: '标题一',
id:'2',
imgList:[
'img1','img2',...
]
},
]
二、尝试
1.HTML上生成特定的class
1.使用接口的id,生成特定的类,这样在控制和找DOM就会更方便
2. 代码里是分类下,图片超出4张才会出现展开/收起按钮
3. 默认不展示收起按钮
<div v-for="item in list">
<div>标题:{{item.title}}</div>
<div :class="`main${item.id}`">
<img v-for="(url,index) in item.imgList.slice(0,4)" :src="url">
</div>
//被控制 展开/收起的图片
<div :class="`main${item.id}`">
<img v-for="(url,index) in item.imgList.slice(4,)" :src="url">
</div>
<div v-if="item.imgList.length>4">
<div :class="`open${item.id}`" @click="toChange(item,'block')">展开</div>
<div :class="`close${item.id}`" @click="toChange(item,'none')" style="display:none;">收起</div>
</div>
</div>
2.控制展开/收起
1.分别获取到 mainDom,openDom ,closeDom
2.下面通过类名获取到的是DOM数组,DOM数组不能用forEach遍历,所以要转一下
// 展开/收起
toChange(item,str){
let mainDom = document.getElementsByClassName(`nr${item.id}`);
let openDom = document.getElementById(`open${item.id}`);
let closeDom = document.getElementById(`close${item.id}`);
mainDom = [...mainDom];
mainDom.forEach(item=>{
item.style.display = str;
})
closeDom.style.display = str;
openDom.style.display = str==='block' ? 'none':'block';
},