您现在的位置是:网站首页> 编程资料编程资料
vue实现超过两行显示展开收起的代码_vue.js_
2023-05-24
325人已围观
简介 vue实现超过两行显示展开收起的代码_vue.js_
vue超过两行显示展开收起
基于vue-cli2,sass,vant(ui组件):https://youzan.github.io/vant/#/zh-CN/home
具体代码如下:
占位{{ item.version }} {{ item.time }} {{ item.title }}{{ item.content }}{{ item.status ? "展开" : "收起" }}
vue多个展开收起功能
需求场景:移动端/h5/公众号页面,有很多分类,每个分类下展示图片,默认超出两张 出现展开和收起功能。

说下思路
这类功能很常见,其实之前也写过;正常思路都是搞个类似单独的变量去控制分类下图片是展开/收起;但是代码很是累赘,于是就想说能不能用原生的代码去写。
接口返回的数据格式大致如下:
list = [ { title: '标题一', id:'1', imgList:[ 'img1','img2',... ] }, { title: '标题一', id:'2', imgList:[ 'img1','img2',... ] }, ] 尝试
1.HTML上生成特定的class
使用接口的id,生成特定的类,这样在控制和找DOM就会更方便
代码里是分类下,图片超出4张才会出现展开/收起按钮
默认不展示收起按钮
标题:{{item.title}}//被控制 展开/收起的图片展开
2.控制展开/收起
分别获取到 mainDom,openDom ,closeDom
下面通过类名获取到的是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'; }, 以上就是今天要讲的内容,本文仅仅简单介绍了平常工作中常见的需求,同一种需求不同状态下写,代码也会不一样,写文章也是为了更好的总结,从中慢慢积累经验。希望能给大家一个参考,也希望大家多多支持。
相关内容
- 解决找不到模块“xxx.vue”或其相应的类型声明问题_vue.js_
- ant design vue 清空upload组件图片缓存的问题_vue.js_
- uniapp表单验证方法详解_javascript技巧_
- 使用jQuery实现简单穿梭框方式_jquery_
- React Native:react-native-code-push报错的解决_React_
- JavaScript本地数据存储sessionStorage与localStorage使用详解_javascript技巧_
- uniapp实现人脸识别功能详细示例_javascript技巧_
- antdv vue upload自定义上传结合表单提交方式_vue.js_
- jQuery样式操作方法整理介绍_jquery_
- 一些超实用的JS常用算法详解(推荐!)_javascript技巧_
