vue高阶组件怎么用(vue更多筛选项小组件使用详解)
类别:编程学习 浏览量:2012
时间:2021-10-18 11:32:08 vue高阶组件怎么用
vue更多筛选项小组件使用详解本文实例为大家分享了vue更多筛选项小组件的实现方法,供大家参考,具体内容如下
效果:
就是一个简单的小效果,当有很多筛选条件时,默认只展示几项,不会觉得很冗余,有需要可以点击展开,进行更过的条件筛选。并且能够自动判断界面的尺寸,决定是否需要更多筛选项。直接把“查询、重置”内置到组件里面了,便于组件样式的实现,还可以进行插槽。
正常大屏
分辨率变小
可见出现了更多筛选的按钮,可以点击下拉
插槽
代码:
<template> <li :class="['colla-wrap']" ref="filter"> <li class="colla-box" ref="filterCont" :style="maxWidth ? 'max-width:' + maxWidth: ''"> <slot></slot> </li> <li class="ctrl"> <li class="deal-b" > <el-button size="mini" type="primary" icon="el-icon-search" @click="clickSearch">查询</el-button> <el-button size="mini" plain icon="el-icon-refresh-left" @click="clickReset">重置</el-button> <slot name="moreBtns"></slot> <li class="deal-b" @click="showCollapse" v-if="autoExpend.more"> <i class="el-icon-arrow-down turnDown" v-if="!autoExpend.collapseVisible"></i> <i class="el-icon-arrow-up turnUp" v-if="autoExpend.collapseVisible"></i> <li v-if="!autoExpend.collapseVisible" class="more-words">更多筛选项</li> <li v-if="autoExpend.collapseVisible" class="more-words">收起筛选</li> </li> </li> </li> </li> </template> <script> export default={ data(){ return{ collapseData:{ collapseVisible:false }, //自动折叠显示更多筛选项 autoExpend:{ more:false, collapseVisible:false, hasTop:false, hasFilter:false }, } }, props:['maxWidth'], mounted(){ this.watchScrollHeight() window.addEventListener("resize", () => { this.watchScrollHeight() }); }, methods:{ clickSearch(){ this.$emit('clickSearch') }, clickReset(){ this.$emit('clickReset') }, showCollapse(){ this.methods('showCollapse') }, showCollapse(){ this.autoExpend.collapseVisible = !this.autoExpend.collapseVisible this.$refs.filterCont.style.height = this.autoExpend.collapseVisible?'auto':'50px' } //尝试监控这个高度 watchScrollHeight(){ let filter = this.$refs.filter; if(filter){ this.$nextTick(() => { this.autoExpend.more = $(filter).find(".colla-box")[0].scrollHeight > 50; }) } //判断下面有没有元素节点 决定这个插槽是否显示 //判断正常搜索框部位插槽 if(this.$refs.filterCont&&this.$refs.filterCont.childNodes.length){ this.autoExpend.hasFilter = true } } } } </script> <style scoped lang="scss"> .colla-wrap{ width: 100%; .colla-box{ max-width: calc(100% - 400px); float: left; box-sizing: border-box; overflow: hidden; height: 50px; >li,button{ float: left; margin-right: 20px; margin-bottom: 20px; } } .ctrl{ display: flex; align-items: flex-start; justify-content: flex-start; color: #409EFF; button{ margin-right: 20px; } .deal-b{ display: flex; align-items: flex-start; flex-wrap: nowrap; .deal-b{ margin-right: 0; margin-bottom: 0; margin-top: 5px; display: flex; align-items: center; cursor: pointer; color: #409EFF; .more-words{ min-width: 75px; } i{ color: #409EFF; margin-right: 5px; } } } } } </style>
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持开心学习网。
您可能感兴趣
- vue中的指令及用法(详解Vue进阶构造属性)
- vue找不到水印设置(Vue使用自定义指令实现页面底部加水印)
- vue路由跳转自动定位在哪里(Vue路由this.route.push跳转页面不刷新的解决方案)
- vue 中后台管理系统(Vue实现学生管理功能)
- vue购物车简单项目(vue实现简单购物车案例)
- vue图片怎么上传服务器(vue-cropper组件实现图片切割上传)
- vue跨域代理怎么写(解决vue $http的get和post请求跨域问题)
- vue慢动作怎么操作(vue开发之moment的介绍与使用)
- vue源码系列教程(vue使用引用库中的方法附源码)
- vue调用组件内部的方法(Vue如何实现组件间通信)
- vue在html里面怎么展示图片(v-html渲染组件问题)
- vueassets文件路径(vue如何根据url下载非同源文件)
- vue加element ui弹窗(Vue中ElementUI分页组件Pagination的使用方法)
- vue验证码怎么用(vue验证码组件使用方法详解)
- vue请求token无效(关于Vue 消除Token过期时刷新页面的重复提示问题)
- vue-router的安装(详解Vue-Router的安装与使用)
- 周杰伦演唱会门票(周杰伦演唱会门票多少钱一张2023)
- 焕然一新 成都轨道集团官方网站改版上线(成都轨道集团官方网站改版上线)
- 成都轨道交通19号线二期全线电通(成都轨道交通19号线二期全线电通)
- 19号线二期全线电通 轨道交通项目最新进展来了(19号线二期全线电通)
- 涉及3条地铁线路 成都这4座轨道交通站点有新名字了(涉及3条地铁线路)
- 来了 成都轨道交通5条线路刷新 进度条(成都轨道交通5条线路刷新)
热门推荐
- python四舍五入怎么用(python3 小数位的四舍五入用两种方法解决round 遇5不进)
- SQLserver中cube:多维数据集实例详解(SQLserver中cube:多维数据集实例详解)
- laravel配置文件动态化(在Laravel 的 Blade 模版中实现定义变量)
- dedecms数据库备份地址(dedecms搬家时出现数据库导入失败的解决方法)
- linux内核从原理到代码详解(探究一个LED如何入门Linux内核)
- css3动画效果图(css3实现波纹特效、H5实现动态波浪效果)
- dedecms怎么设置栏目(DEDECMS实现在标签中嵌套调用SQL的方法)
- sql server中随机函数NewID()和Rand()
- dedecms是静态吗(dedecms全站伪静态的实现方法及注意事项)
- laravel获取访问来路的函数(Laravel实现搜索的时候分页并携带参数)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9