【JS】DatePicker组件开发

课程前言:

慕课网 -- DatePicker组件开发


课程准备:

HTML、CSS、JavaScript基础、浏览器事件

静态结构的编写、日历数据、数据渲染、事件处理


静态结构的编写:

日期组件的结构和样式

header分为三部分,向上翻页的button,向下翻页的button,还有就是中间的当前月份显示。

body部分是一个表格的呈现,分为两个部分,表头是周一到周日的呈现,表格内容是每一个单元格就是一个日期。


组件的样式命名,会比较长(复杂),开发的是一个组件,那这个组件就会被应用到各个页面上,如果过于简单,就会跟页面上的元素class命名冲突,带来不必要的麻烦。因此,组件的样式命名就比较独特,可以长一点。

a元素实现按钮,是因a自带手形图标。一般来说,可点击的按钮都需要一个提示。


静态样式的编写:

box-shadow:给盒子一个悬浮于页面的效果,box-shadow:2px2px8px2pxrgba(128,128,128,.3);

级联选择器:避免与外界发生冲突。background-color:#f0f0f0; 它是区别于白色的背景色。为了使字体符号更像图标,会设置字体的样式,font-family:Serif; a标签有href属性时,就会有下划线。

border-collapse:collapse;是说,table中,相邻的两个表格线会折叠一条。选中状态下 shift+cmd+上下箭头即上下移动;


日期对象:

new Date (year,month-1,date) 其中,月份需要-1.越界自动 进退位,还有 getFullYear() ,getMonth() , getDate() .

getYear()  是说,距离 1900 年多少年,比如2017 getYear() 后就是 117年;但getFullYear() 就是 2017年了。

getDay() 当前日期在一周中是周几。

当月第一天 new Date(year, month-1, 1) 日期指定1,月份是从0开始的,所以要-1,year也都是正常的 2017 呀等。

当月最后一天 new Date(year, month, 0) 日期指定 0,月份是month,没有减1,其实就是下个月咯,下个月的第0天,表示上一个月的最后一天。(因月份的最后一天,不一定都是31,因此,我们用 下一个月的 0 来表示 这个月的最后一天。这是利用了日期的自动进退位。)

神奇的最后一天

星期一 到 星期天,[1,2,3,4,5,6,0] ,这个数组是 getDay()  的返回值。一个星期的开始,是从周天开始的,也就是0开始的,你知道为什么吗?✌️


获取日历数据:

利用JS获取日历的核心数据

这个return和window很不错哦

日期数据的渲染:

有时聊渲染,其实就是一个html。

渲染日期数据

整个过程细心就好了,其实就是比较繁琐。 < 小于号,>大于号,因普通的跟看起来有点不同,那就调整一下字体就好了。span中间是当前月份的显示,都是从 monthData中拿到,前期数据的准备非常重要。


输入框的展开与收起:

优化着手点有两方面:

1.当用户点击输入框的时候,日期组件才可以显示,不能一打开页面,它就在,太不友好了;

2.目前的日期组件的主题结构 wrapper header body是占据文档流的,如果页面里还有其他的内容,会因日期的出行,下移的,因此将其样式改为绝对定位。

元素的显示与隐藏:方式很多样;最通用是通过class来控制,默认是隐藏,除非多了一个 block 的样式,后者覆盖前者,wrapper就才显示出来。  .classList.remove 与 .classList.add 的 使用。  isOpen 布尔值 来记录当前是关闭状态还是展开状态。

日期组件的绝对定位:目标是希望它出现在输入框的下方,所以就要先找到输入框目前在页面的哪个位置呢: var left = $input.offsetLeft;  var top = $input.offsetTop;   var height = $input.offsetHeight;   $wrapper.style.top = top + height + 9 +'px';   $wrapper.style.left = left + 'px';(切记,这里用style给宽高的时候,加上 px 呢。)

日期组件的展开与收起


月份切换:

本节课的出发点:左右按钮切换时,进入上一月,或者下一月。初始化的时候,给按钮绑定事件。但这种情况,是在组件初始化的时候才有效,事件只绑定了一次;但页面渲染之后,内容里是根据按钮再重新渲染的,我们的按钮也是感觉HTML字符串再重新渲染的,因此就会有按钮不断的销毁与重建。

月份切换的button

datepicker.render('prev')  datepicker.render('next') 是谁:

这个方法,需要一个direction参数哦

日期点击选中:

data-*是一个比较新的API,老的浏览器不能使用。*是要替换成自己命名的字符。为一个标签添加一个此属性后,js取值的时候是: target.dataset.d;     target:添加此属性的标签对象    dataset:固定写法    d:添加的属性名的后半部分,即data-*中“-”后自己命名的字符。

日期小元素的选中
日期巧妙格式化

日期组件的使用:

JS的调用方法由繁入简

调用方法由繁入简,最后只有 .init 里,传一个样式。

最后的页面,只有一个输入框

而一个日期组件的出现,就依靠这个输入框了。而这个输入框的样式,因为不属于组件,因此就写在页面里咯~


课程总结(组件开发流程):

使用HTML合理规划组件结构;

为组件编写美观的样式;

如何使用JavaScript获取组件所需数据;

将数据与HTML结构结合;

用户事件处理;

页面的JS框架

整个日期组件的出现,就是从 init 开始,然后 init 在绑定相关的点击操作之前,首先调用 render 来渲染这个的日期组件;然后,render里,写的是 日期组件中的数据,还有左右两边的上下按钮;render里的数据,则是从 buildUi 里来的,包括样式,都是一致的。


小技能:

var$input =document.querySelector('input');

$wrapper.classList.add('ui-datepicker-wrapper-show');

$wrapper.classList.remove('ui-datepicker-wrapper-show');

if(!$target.classList.contains('ui-datepicker-btn'))return;

if($target.tagName.toLowerCase() !='td')return;

不写备注了,试试看,能否想起来啦。



后续可完善的功能:

如何在移动端使用日期组件;

当页面比较复杂的时候,如何处理,弹出框的位子;

如何标记上一个月与下一个月的日期,使它们拥有不同的样式;

某一些日期可点,某一些日期不可点。


写在最后,写给自己:

整个组件开发的核心,是日期数据的获取,那老师都已经给出思路了,我是否愿意写一写可完善的功能;如果我觉得JS不那么的熟悉,是否可以使用React重新开发该框架呢?如果想要重写,大概要多久呢?

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,362评论 5 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,330评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,247评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,560评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,580评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,569评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,929评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,587评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,840评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,596评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,678评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,366评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,945评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,929评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,165评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,271评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,403评论 2 342

推荐阅读更多精彩内容