动态控制查询条件,自定义查询时间组件范围

开场诗

-岁暮阴阳催短景,天涯霜雪霁寒宵。

  • 五更鼓角声悲壮,三峡星河影动摇。

  • 野哭千家闻战伐,夷歌数处起渔樵。

  • 卧龙跃马终黄土,人事音书漫寂寥。

一、序言

大家好,这里是流光的频道,又到了和大家分享的时间,最近在工作中遇到了两个比较有意思的点和大家分享一下。

遇到的问题

1.查询条件过多如何展示

大家都遇到过一个页面上面是搜索框下面是展示的table,通过上面的查询条件。下方实时的变换展示内容,但是当上方查询条件多达10多个的时候页面可能就不太美观造成下方的数据看不多(如图一所示)

图一

2.如何根据自己需求动态更改日期选择框的时间范围

大家在实际工作中肯定会用到过RangePicker时间范围的选择框他里面有本月、本周、本年等等选择范围以本月举例,当我选择本月它默认是从1号到30或者31号但是如果我想要的是上月25号到本月24号算一个月他就没有办法进行选择。当我选择本月它如图二所示

如何解决

1.动态控制显示查询条件

我的想法是当我查询的时候把一些经常用的查询条件放在外面,不经常用的通过一个按钮来控制它的显示与隐藏,通过这个想法我想了两个解决方法:
1通过使用SearchFormer(公司内部自家研发的组件库)自带的extraButtons来控制展示与隐藏
通过按钮的点击函数来控制useState变量highsearch的true或false来动态显示不同展示内容

但是好像ant的组件库没有这个组件所以我贴和ant的组件库想到通过javascript代码来动态向组件里面添加一个按钮给它先找到包裹组件的div

js 复制代码
  useEffect(() => {
    // 创建一个按钮元素
    var button = document.createElement('button');
    // 设置按钮文本
    button.innerHTML = '高级查询';
    //设置点击函数
    button.onclick = onHandleHigh()
    // 获取 div 元素
    var div = document.querySelector('hv-search-former-buttons');
    // 将按钮添加到 div 元素中
    div.appendChild(button);

  }, []);
  //还可以通过button.style来设置样式

效果如下GIF

2.自定义时间框日期范围

通过重写时间框的ranges方法自定义时间范围

js 复制代码
//时间框
  <RangePicker
         allowClear={false}
         style={{ width: '100%' }}
         onChange={onChange2}
         ranges={getRanges()}
  />
  
   // 获取上个月的25号到本月的24号的时间范围
  const getLastMonthRange = () => {
    const startDate = moment()
      .subtract(1, 'months')
      .date(25);
    const endDate = moment().date(24);
    return [startDate, endDate];
  };

  // 根据月份设置不同的时间范围
  const getRanges = () => {
    console.log(moment());
    console.log(moment().startOf('week'));
    if (moment(new Date(), 'MM') === 1) {
      return {
        今天: [moment(), moment()],
        本月: [moment().date(1), moment().date(24)],
        本周: [moment().startOf('week'), moment().endOf('week')],
        本年: [moment().startOf('year'), moment().endOf('year')]
      };
    }
    if (moment(new Date(), 'MM') === 12) {
      return {
        今天: [moment(), moment()],
        本月: [
          moment()
            .subtract(1, 'months')
            .date(25),
          moment().date(31)
        ],
        本周: [moment().startOf('week'), moment().endOf('week')],
        本年: [moment().startOf('year'), moment().endOf('year')]
      };
    }
    // 其他月份的处理
    return {
      今天: [moment(), moment()],
      本月: getLastMonthRange(),
      本周: [moment().startOf('week'), moment().endOf('week')],
      本年: [moment().startOf('year'), moment().endOf('year')]
    };
  };

随想

今天的分享就到这里了大家如果有更好的办法欢迎大家留言讨论

相关推荐
贩卖纯净水.3 分钟前
Webpack常见的插件和模式
前端·webpack·node.js
brzhang11 分钟前
Flutter 调用原生代码,看这篇就够了:从零教你搭起通信的桥
前端·后端·架构
袁煦丞13 分钟前
知识管理的六边形战士Trilium Notes:cpolar内网穿透实验室第520个成功挑战
前端·程序员·远程工作
失败又激情的man21 分钟前
python爬虫之数据存储
前端·数据库·python
互联网搬砖老肖22 分钟前
Web 架构之 API 安全防护:防刷、防爬、防泄漏
前端·安全·架构
小声读源码1 小时前
【技巧】dify前端源代码修改第一弹-增加tab页
前端·pnpm·next.js·dify
假客套1 小时前
2025 后端自学UNIAPP【项目实战:旅游项目】7、景点详情页面【完结】
前端·uni-app·旅游
Captaincc1 小时前
Ilya 现身多大毕业演讲:AI 会完成我们能做的一切
前端·ai编程
teeeeeeemo2 小时前
Vue数据响应式原理解析
前端·javascript·vue.js·笔记·前端框架·vue
Sahas10192 小时前
__VUE_PROD_HYDRATION_MISMATCH_DETAILS__ is not explicitly defined.
前端·javascript·vue.js