IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> 仿Antd组件之DatePicker组件实现(简易) -> 正文阅读

[JavaScript知识库]仿Antd组件之DatePicker组件实现(简易)

仓库链接:组件地址
自己的CodePen在线预览链接:DatePicker(by cos)
对应组件demo:Ant Design DatePicker日期选择框

心得

  • 契机是什么才不说呢
  • 也算是第一次用React写自己的小组件,可能封装性还不行bug也还有不少,写的代码自己复盘的时候也很想吐槽2333不过也是个很有意思的事!比如点击日期选择器外关闭日期选择器这个功能就纠结了我好长时间qwq,但是写完真的很快乐!
  • 使用了React的ref判断点击事件发生在组件内部还是外部
  • 实现自己的组件是很cool的事!虽然有时候也会感觉有点重复造轮子
  • 在学习antd组件的实现同时也感受到了其实现的不少细节,望尘莫及ovo,以后有机会还会有优化哒,增加更多api和功能和自定义大小设置等。

组件介绍

DatePicker组件

DatePicker 组件开发
代码及在线预览地址:DatePicker(by cos)

  1. 日、月、年选择面板的实现
    交互:
    a.日面板实现:实现点击日期选择具体日期,点击头部面部左右箭头可前往上一年/下一年、上一月/下一月
    b.月面板实现:点击日面板头部月份进入,点击月份则选择具体月份并返回日面板,点击头部面部左右箭头前往上一年/下一年
    c.年面板实现:点击日面板头部月份进入,以十年为区间,点击年份则选择该年并返回日面板,点击头部面部左右箭头前往上个十年/下个十年
    d.根据输入框输入实时变换日期
  2. 对外API的实现
    a. 支持默认日期的设置 defaultDate 通过设置defaultDate为moment对象实现默认日期的设置
    b. 支持日期的获取 onDateChange 通过日期变化的回调函数获取当前日期,返回moment对象
    示例:
class App extends Component {
    constructor(props) {
        super(props);
        this.state = {
            nowDate: 'No Value!'
        }
    }
    handleDateChange(date) {
        this.setState({nowDate: date.format('YYYY-MM-DD')});
    }
    render() {
        return (
            <div className="App">
                <div>nowDate: {this.state.nowDate}</div>
                <DatePicker defaultDate={moment()} onDateChange={(date) => this.handleDateChange(date)} />
            </div>
        );
    }
}
  1. 面板展示与切换动画
    通过 picker-panel 中初始透明度 opacity为 0,变化原点transform-origin为左上角,初始大小为 scale(0) ,通过自定义属性 data-active 为true控制显示
.picker-panel {
    z-index: 10;
    position: absolute;
    background-color: white;
    top: 30px;
    left: 0;
    width: 300px;
    height: 300px;
    border-radius: 3px;
    border: 1px solid $gray-4;
    box-shadow:2px 2px 10px rgba(0, 0, 0, 0.4);

    display: flex;
    flex-direction: column;

    opacity: 0;
    transform: scale(0);
    transform-origin: top left;
    transition: all 300ms ease-in-out;
    &[data-active=true] {
        transform: scale(1);
        opacity: 1;
    }
}
  1. 界面展示
  • 初始值
    请添加图片描述

  • 选择其他日期
    在这里插入图片描述

  • 下一年
    请添加图片描述

  • 上一个月

请添加图片描述

  • 进入年面板
    请添加图片描述

  • 切换年面板

请添加图片描述

  • 月面板

请添加图片描述

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-03-12 17:23:13  更:2022-03-12 17:23:39 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/10 16:32:27-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码