如何在移动端更好地使用HTML5 date input

 我来答
从空去听8
2017-09-29 · TA获得超过7439个赞
知道大有可为答主
回答量:6907
采纳率:93%
帮助的人:5580万
展开全部
众所周知,HTML5新增了几种input类型,比如email, number, url, range, date等。这些input类型在一定程度上方便了我们做输入限制和数据校验。但是不同的浏览器厂商的实现方式又不太一样,导致在UI和交互上有细微的差别。今天就来谈谈date这个比较有用的元素。

其实date只是Date pickers中的一种,其他的还有month, week, time, datetime, datetime-local等,分别针对不同的时间-日期选择场景。以往我们要实现类似的日期和时间选择,通常要自己封装一个组件,或者使用现成的第三方插件。这类插件也多如牛毛,质量参差不齐,也很难满足所有的业务需求。如果有原生的控件支持,不但可以省去使用插件的麻烦,还可以获得原生的性能优势和体验上的一致性。HTML5 date input就是为此而生的。然而,正如前面提到的,即便是有标准,也不能保证所有浏览器上都是一样的。PC浏览器就不说了,IE11都不支持。今天主要讨论下如何在移动端使用date input。

移动端date input大概是这样的(手机自带浏览器)

date input
弹出的日期选择界面还过得去,但是date input本身的UI却太土了。你可能想到了用CSS设置样式,但试过之后你会发现,Designer随便给个UI都够你去折腾的了。stackoverflow上有个答案,关于如何自定义date input样式的,效果仍然丑到爆。

这时候就需要转变下思路了。

既然设置date input的样式如此麻烦,为什么不用其他元素做UI,而它自己只负责交互呢?比如可以用text input,甚至div做日期展示。这类元素的样式设置起来容易多了,而且兼容性也较好。这里我们选择text input,原因在后面说明。

先看效果:

placeholder

pick date

display
实现原理很简单,就是用一个text input做初始化日期展示,右边的向下箭头用label实现,设置for属性为text input的id。这样点击label时自动聚焦到input。text input获取焦点
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式