实现效果如下:
需求:
由于后台搜索选项有很多,影响页面美观,所以一进来要隐藏一部分搜索项,只保留1行,
点击【展开搜索】按钮的时候才显示全部,点击【收起搜索】按钮又收起部分,保留1行。
需求分析:
由于不太好控制行数,因为不同屏幕尺寸展示的1行的内容并不相同(不考虑移动端),所以考虑用显示高度来控制。
解决思路:
所以这里通过控制搜索区域的高度来实现展开和收起搜索功能。
页面一进来是收起搜索状态,控制搜索区域的高度为120px,超出部分隐藏。
点击展开搜索的时候,调整搜索区域的高度为”auto"
定义变量:showAll控制状态
代码解析:
<el-button type="text" style="margin-left:10px" id="closeSearchBtn" @click="closeSearch"> {{word}} <i :class="showAll ? 'el-icon-arrow-up ': 'el-icon-arrow-down'"></i> </el-button>
当showAll为false的时候,即搜索区域处于收起状态,此时将按钮文字变为“展开搜索”,图标变为向下(el-icon-arrow-down)
当showAll为ture的时候,即搜索区域全部展开了,将按钮文字变成“收起搜索”,图标变成向上(el-icon-arrow-up)
data(){ return{ showAll:true;//是否展开全部 } } computed: { word: function() { if (this.showAll == false) { //对文字进行处理 return "展开搜索"; } else { return "收起搜索"; } } },
mounted()里调用closeSearch函数,页面一进来将this.showAll设为false,即处于收起状态。所以data里最初给showAll定义的时候设为true.
给搜索区域的ID设为“searchBox” ,
当showAll为false的时候,设置搜索区域高度为120px,否则高度自动。
mounted() { /** * 收起搜索 */ this.$nextTick(function() { this.closeSearch(); }); }, methods:{ closeSearch() { this.showAll = !this.showAll; var searchBoxHeght = document.getElementById("searchBox"); if (this.showAll == false) { searchBoxHeght.style.height = 60 + "px"; } else { searchBoxHeght.style.height = "auto"; } } }
CSS中关键的设置不要忘记。
#searchBox { overflow: hidden; }
到此这篇关于vue element-ul实现展开和收起功能的实例代码的文章就介绍到这了,更多相关vue element-ul展开和收起内容请搜索站长技术以前的文章或继续浏览下面的相关文章希望大家以后多多支持站长技术!
下面是我用ajax实现的输入框自动补全功能,数据库数据很少,大体模仿出了百度首...
微软昨天发布了 Windows 10 最新的内部预览版更新 (Insider Preview Build 21337...
前段时间一直忙于期末考试和找实习,好久没写博客了。 这段时间做了个小项目,包...
下面通过图文并茂的方式给大家介绍正则表达式替换原则,具体内容请看下文。 一、...
最常用的向HTML中插入视频的方法有两种,一种是古老的object/object标签,一种是...
在本示例中,我们将向您展示如何将对象转换成json格式并通过spring mvc框架返回...
运用bootstrap,jquery和ajax显示一些数据,附加删除功能并且点击能弹出模态框详...
** 文章目录 一、Spring综述 1.1 jdk环境依赖 1.2 Spring介绍 二、IOC理论推导 2...
我们都知道,保护敏感信息至关重要。幸运的是,现在大多数企业都拥有可靠的网络...
最近某APP删除用户相册里保存的截图事件闹得沸沸扬扬的,先不管这到底是不是有意...