资讯专栏INFORMATION COLUMN

徒手撸UI之TimePicker

Codeing_ls / 1416人阅读

摘要:是一个组件库目前拥有的组件语法编写,无依赖原生模块化,以上支持,请开启静态服务器预览效果,静态服务器传送门采用变量配置样式辛苦造轮子,欢迎来仓库四月份找工作,求内推,坐标深圳写在前面去年年底项目中尝试着写过一个分页的组件,然后就有了写的想法

</>复制代码

  1. QingUI是一个UI组件库

    目前拥有的组件:DatePicker, TimePicker, Paginator, Tree, Cascader, Checkbox, Radio, Switch, InputNumber, Input

    ES6语法编写,无依赖

    原生模块化,Chrome63以上支持,请开启静态服务器预览效果,静态服务器传送门

    采用CSS变量配置样式

    辛苦造轮子,欢迎来github仓库star:https://github.com/veedrin/qing

    四月份找工作,求内推,坐标深圳
写在前面

去年年底项目中尝试着写过一个分页的Angular组件,然后就有了写QingUI的想法

过程还是非常有意思的

接下来我会用几篇文章分别介绍每个组件的大概思路,请大家耐心等待

这一篇介绍TimePicker日期选择器

最重要的,求star,求fork,求内推

</>复制代码

  1. QingUI
少废话,先上图

当前时间

介绍DatePicker的文章写的时候已经凌晨了,毕竟那天commit了50多次,所以有点草率,这回我尽量写的清楚一点

初始加载TimePicker的时候肯定显示当前的时间,所以我们首先要获取当前的时间

当前时间好说,只是ES6提供了解构赋值正好可以在这里派上用场

直接返回一个数组,需要的时候一次性赋值就好了

如果不需要这么多,没问题,ES6不仅可以批发,还可以零售,贴不贴心!

为什么秒不直接赋值呢?因为我觉得很少有场景我们需要精确到秒,还不如初始直接给个0,省的别人点一下,他要精确到秒是他的事

</>复制代码

  1. constructor() {
  2. [this.H, this.M, ] = this.nowTime();
  3. this.S = 0;
  4. }
  5. nowTime() {
  6. const date = new Date();
  7. return [date.getHours(), date.getMinutes(), date.getSeconds()];
  8. }

当用户选择的时候,选中的就会高亮,之前的高亮会取消

我们可以粗暴一点,每次点击都运行一个for循环,找到高亮,取消高亮,场子清完以后再将当前选中的高亮

不过这样性能肯定是不好的

如果我把选中的时间缓存起来

每次点击的时候我还记得上次高亮的在哪,直接处理它就好了,少了一个for循环是不是好多了

不过要注意,每次点击都要把新值缓存,它就是个跟屁虫,可不能掉队

</>复制代码

  1. constructor() {
  2. [this.oldH, this.oldM, this.oldS] = [this.H, this.M, this.S];
  3. }
切换

时钟、分钟、秒钟,总共有三个面板,所以我设置三个按钮,时间格动态渲染

假如用户点击时钟按钮,他要怎么辨别刚才点的是哪个按钮呢?

下意识的,我们会想到,当前活跃的,我们就给它置灰,以来作区分,二来省的用户无聊老在一个地方点来点去造成重复渲染

我以前也有过一点经验,就是buttondisabled属性并不是通过true和false来控制的

真正控制它是否置灰的,是有没有这个属性

我觉得这个设计...

所以我们写一个控制置灰的函数,同样,oldDisabled是用来缓存的

</>复制代码

  1. ableAndDisableEvent(ableNode) {
  2. if (this.oldDisabled) {
  3. this.oldDisabled.removeAttribute("disabled");
  4. }
  5. ableNode.setAttribute("disabled", "");
  6. this.oldDisabled = ableNode;
  7. }

有时候我们有这样的需求,虽然点击事件是响应用户操作的,但偶尔我们自己也希望触发一下事件

用户可以触发点击事件,那么程序可以吗?

其实是可以的,.click(),就这么简单

说实话这个我也是第一次见,可能是我比较孤陋寡闻吧...

</>复制代码

  1. this.oldDisabled.click();
转数字

当我们点击时,获取到的innerHTML实际上是一个字符串

我希望在入口把关,保证this.H; this.M; this.S;都是数字类型

于是我们就要把字符串类型的数字转成真数字,这倒不难

我曾经测过几种字符串类型的数字转成真数字的方法,当然,我说的是正整数

parseInt()

parseFlout()

Number()

Math.floor()

num - 0

性能肯定是num - 0最好,但是这样并不是特别正规

除此之外,性能最好的是parseInt()parseFlout()要考虑小数位,Number()估计是内部的类型转换比较复杂

除了语义化并不是特别好之外,我平常都喜欢用parseInt()

但这不是重点

重点是ES6在Number下面也挂载了该方法,window.parseInt()Number.parseInt()都是可以的,为什么这样做呢?

因为JS的全局对象window实在是太复杂了,它不仅是全局对象,还是窗口对象,连所有的全局变量都挂在它下面

所以W3C希望改变这个现状,尽量减少甚至取消window下面的属性

这也是为什么在ES6模块内,指向全局的this等于undefined

所以,如果兼容性允许的话,尽量用Number.parseInt()代替window.parseInt(),为美妙的JS尽一份力

Everything Based On JavaScript就不远了吧

格式化

比较正规的时间表盘都会显示两位数,比如3点20分,会写成03: 20

所以我们也需要一个两位数的格式化函数

为什么需要String(num).length === 1这个判断条件?

因为有时传进来的参数已经格式化过了,而它实际上又小于10,所以需要过滤掉它们

</>复制代码

  1. twoDigitsFormat(num) {
  2. if (String(num).length === 1 && num < 10) {
  3. num = `0${num}`;
  4. }
  5. return num;
  6. }

然后我再用一个漏斗函数把变化收集起来,统一更新

</>复制代码

  1. timeChangeEvent(hour, minute, second) {
  2. hour ? this.H = hour : "";
  3. minute ? this.M = minute : "";
  4. second ? this.S = second : "";
  5. this.$view.innerHTML = this.timeFormat(this.H, this.M, this.S);
  6. }

至于显示成最终的时间格式,我们有它

</>复制代码

  1. timeFormat(hour = 0, minute = 0, second = 0) {
  2. hour = this.twoDigitsFormat(hour);
  3. minute = this.twoDigitsFormat(minute);
  4. second = this.twoDigitsFormat(second);
  5. return `${hour} : ${minute} : ${second}`;
  6. }
写在后面

首先,这个时间选择器确实不好看,我将来可能会重构

然后,时间选择器也确实比较简单,比日期选择器代码少多了

不过还是可以自己尝试着自己写一个,一切都在细节里

下一篇文章介绍Paginator,敬请期待

最后,求star,求fork,求内推

</>复制代码

  1. QingUI

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/93667.html

相关文章

  • 徒手UIDatePicker

    摘要:是一个组件库目前拥有的组件语法编写,无依赖原生模块化,以上支持,请开启静态服务器预览效果,静态服务器传送门采用变量配置样式辛苦造轮子,欢迎来仓库四月份找工作,求内推,坐标深圳写在前面去年年底项目中尝试着写过一个分页的组件,然后就有了写的想法 QingUI是一个UI组件库目前拥有的组件:DatePicker, TimePicker, Paginator, Tree, Cascader, ...

    zilu 评论0 收藏0
  • 徒手UIPaginator

    摘要:是一个组件库目前拥有的组件语法编写,无依赖原生模块化,以上支持,请开启静态服务器预览效果,静态服务器传送门采用变量配置样式辛苦造轮子,欢迎来仓库四月份找工作,求内推,坐标深圳写在前面去年年底项目中尝试着写过一个分页的组件,然后就有了写的想法 QingUI是一个UI组件库目前拥有的组件:DatePicker, TimePicker, Paginator, Tree, Cascader, ...

    liuhh 评论0 收藏0
  • 徒手UICascader

    摘要:但是如果一刹那我不想选江疏影了,我想选张雨绮因为胸大,首先我要从霍思燕换到高圆圆,然后转到张雨绮,选中展示出来,这时候就要先删除霍思燕,然后把高圆圆和张雨绮进来。 QingUI是一个UI组件库目前拥有的组件:DatePicker, TimePicker, Paginator, Tree, Cascader, Checkbox, Radio, Switch, InputNumber, I...

    junnplus 评论0 收藏0
  • 徒手UITree

    摘要:是一个组件库目前拥有的组件语法编写,无依赖原生模块化,以上支持,请开启静态服务器预览效果,静态服务器传送门采用变量配置样式辛苦造轮子,欢迎来仓库四月份找工作,求内推,坐标深圳写在前面去年年底项目中尝试着写过一个分页的组件,然后就有了写的想法 QingUI是一个UI组件库目前拥有的组件:DatePicker, TimePicker, Paginator, Tree, Cascader, ...

    2i18ns 评论0 收藏0
  • 一言不合造轮子--一个ReactTimePicker

    摘要:时间选择的表盘其实有两个,一个是小时的选择,另一个则是分钟的选择。也就是说,第一步选择小时,第二部选择分钟它是一个小时制的时间选择器。而则用于处理拖拽事件,标记着当前是否处于被拖拽状态。 本文的源码全部位于github项目仓库react-times,如果有差异请以github为准。最终线上DEMO可见react-times github page 文章记录了一次创建独立React组件...

    lifesimple 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<