当前位置: 首页 > news >正文

宿迁公司企业网站建设自己做家具的网站

宿迁公司企业网站建设,自己做家具的网站,大连百度推广怎么做,建立旅游网站的目的这周遇到了一个很诡异但又很合理的需求。掉了一周头发,死了很多脑细胞终于上线了。必须总结一下,不然对不起自己哈哈哈。 一、需求描述 默认当前日期时间不可清空。 功能 默认时间如下: 目的:将时间改为 2014-08-01 ~ 2014-08…

这周遇到了一个很诡异但又很合理的需求。掉了一周头发,死了很多脑细胞终于上线了。必须总结一下,不然对不起自己哈哈哈。

一、需求描述

默认当前日期时间不可清空。

功能

默认时间如下:

目的:将时间改为 2014-08-01 ~ 2014-08-12

antd交互

修改开始时间为 2014-08-01,结束时间的时间选择范围首先弹出的是 2014 年 12月 和 2015年1月。

 也就是说,当改变开始时间后,跳转到结束日期时,日期选择面板根据当前时间而定的。

但实际上,这是非常逆人性化的。

因为,当我们修改时间的时候,往往第二个时间的修改是依赖于第一个选择的时间的。

需求交互

于是,产品就提出了,希望,选择第二个时间的时候,展示的时间范围根据第一个选择的时间而定。
即当修改开始时间为 2014-08-01,结束时间的时间选择范围首先弹出的是 2014年 08月 和 2015年 09 月。

 好,希望我把需求描述清楚了。 

文字再解释一遍:

比如:
当前功能:当前选择时间为:2015-01-01 至 2015-01-01,
修改开始时间为 2014-08-01,结束时间的时间选择范围首先弹出的是 2014 年 12月 和 2015年1月。
期待功能:
修改开始时间为 2014-08-01,结束时间的时间选择范围首先弹出的是 2014年 8月 和 2014年 9 月。

二、解决方法

在看了一天日期组件的api之后,我终于找到了 使时间范围自动调整的方法。 那就是在 focus 的时候,清空当前时间。

所以解决的思路就很明确了,在 onFocus 事件中清空 当前时间。

下面我就在代码中,解释思路。

import React, { useEffect, useState } from "react";
import "./index.css";
import type { DatePickerProps } from "antd";
import { DatePicker, Space } from "antd";
import dayjs from "dayjs";
import customParseFormat from "dayjs/plugin/customParseFormat";
import isBetween from "dayjs/plugin/isBetween";
dayjs.extend(customParseFormat);
dayjs.extend(isBetween);const { RangePicker } = DatePicker;const dateFormat = "YYYY/MM/DD";const App: React.FC = () => {const [rangValue, setRangValue] = useState([dayjs(),dayjs().add(2, "month")]) as any;const [originValue, setOriValue] = useState(rangValue);const onFocus = (f: any) => {// 获取当前聚焦的值(不同的环境可能聚焦的值存的位置不同,要打印出来看看哪个属性是当前值)const value = f.srcElement._value;const isStart =dayjs(rangValue[0]).format(dateFormat) ===dayjs(value).format(dateFormat);// 聚焦在哪一个,就清空哪一个setRangValue([isStart ? "" : rangValue[0], isStart ? rangValue[1] : ""]);};// 清空之后如果用户不选择当前时间,则当前时间会被清空。 所以,要在 blur 的时候 用缓存下来的上次数据去补齐const onBlur = (b) => {setRangValue([rangValue[0] || originValue[0],rangValue[1] || originValue[1]]);setOriValue(rangValue);};// 用户有两种关闭形式,一种是跳转到另一个时间选择框,一种是鼠标点击其他区域,时间范围选择框自动关掉。于是,需要在时间范围选择框关掉的时候,再次补齐const onOpenChange = (open) => {if (!open) {setRangValue([rangValue[0] || originValue[0],rangValue[1] || originValue[1]]);setOriValue(rangValue);}};return (<Space direction="vertical" size={12}><RangePickervalue={rangValue}format={dateFormat}onFocus={onFocus}onBlur={onBlur}onOpenChange={onOpenChange}/></Space>);
};export default App;

以上就是这个需求的解决思路,但是这个解决方法是存在一些风险的。

即,在focus 事件中能否判断出当前focus 的是开始时间还是结束时间。

于是,我给antd 官方提了issue,希望新增加一个数据,去实现该跟随功能,或者在onfocus事件中多暴露一个参数。

欢迎大家前去支持: 日期组件时间范围动态跟随(can rangepicker component provied prop to achieve paneltime dynamically followed pre chosen time) · Issue #40680 · ant-design/ant-design · GitHub

三、解决问题过程

讲完了需求解决的思路和风险,透露一下我做这个需求的心路历程。

1、需求沟通

首先,这个需求其实很小,产品用一句话描述。 我看了几遍,都没有理解,得耗费了10分钟去跟产品沟通他要的交互和效果。

2、看文档

沟通清楚了需求,我觉得这个需求很合理,antd 应该有支持,翻翻文档,半小时内就能解决。

3、方法尝试

① 尝试属性:defaultpickValue,后发现defaultpickvalue 仅在第一次点击的时候生效。

② 尝试 在 onCalendarchange 重新设置 时间,更改之后dom 不更新。

③ 尝试 disabledate,使除了第一次选择的时间之外的相邻月份外全部disable, 无效。

经过了以上三种方式的尝试,我 finally 看到了onfocus 属性,抱着试一试的属性,他生效了!!! 

4、收尾

今天也跟同事针对这个问题进行了讨论,

问题1: 为什么在oncalendarchange 中修改绑定的时间不生效?

最后的结论是,在oncalendarchange 触发后,自动触发了 input 函数的 onChange, 而在calendar中改变的时间,没有更新,onChange 函数拿到的还是旧的值。

也就是说,onchange 把 oncalendar 中的修改覆盖了。

问题2: 为什么要用兜底?这样不绕吗?

这个问题很尴尬哈哈哈,因为,这是业务需求的,时间不能清空。 所以需要补齐时间。

5、复盘

其实这个问题的解决过程还是太长了。 一是对api 的熟悉度不高,二是,缺乏经验无法描述出最核心的问题。

在后面确认使用 onfocus 以后,以及探讨问题1 的时候,在stackoverflow 发现了一些类似的问题。

比如: reactjs - how to set start or end date of antD rangePicker to empty - Stack Overflow

http://www.yayakq.cn/news/667946/

相关文章:

  • 建站成本特性设计的网站
  • 东营免费网站制作市场营销方案范文5篇
  • 免费crm网站下载的软件用wordpress做小程序
  • 武义建设工程网站怎样做英文网站
  • 专业站网站制作公司哪家专业
  • 网站建设费1万多入什么科目山东省住房和建设网站首页
  • 网站正能量下载直接进入主页可以吗安全吗软件开发工具03173课后题
  • 网站建设设计图软件广东省石油化工建设集团公司网站
  • 团购网站开发代码百度搜索量排名
  • 网站建设百度搜索到左边的图插件 wordpress开发教程
  • 用什么网站做pathway分析网站建设怎么选公司
  • 静态网站设计怎么做广州越秀区天气预报
  • 江苏赛华建设监理有限公司网站html5网站正在建设中模板下载
  • 网站备案对应的ip地址做网站站怎么赚钱
  • 专门找事做的网站把网站传到服务器上怎么做
  • 网站建设费用 无形资产wordpress枚举用户名
  • 怎么用dw做响应式网站自己做的电影网站犯法吗
  • 做效果图的兼职网站mip网站
  • 重庆电力建设设计公司网站微信公众号平台入口官网
  • 邯郸网站建设优化排名镇江网站建设咨询
  • 遵义网站建设中心wordpress多级分类
  • 做网站现在要多少钱甘肃政务服务网
  • wordpress微信网站模板关于茶叶的网站模板免费下载
  • 做软件的中介网站有服务器做网站
  • 自己做个网站多少钱网站后台修改图片
  • 网站建设服务商推荐门户网站部署方案
  • 濮阳建站推广哪家好网站英文版怎么做
  • 深圳建设网站的公司简介静态营销网站代码
  • asp网站源码免费下载天眼通公司查询在线
  • 上传网站到二级域名网站建设 培训 南充