【发布时间】:2018-07-14 03:22:44
【问题描述】:
有没有办法在输入元素的焦点上激活原生 HTML5 日期选择器下拉菜单?
大型输入元素:
目前我只能通过单击输入元素最右侧的箭头来使用日历。
箭头的大输入元素点击
我想在输入元素的焦点上激活这个日历。
这是有问题的代码。
<!DOCTYPE html>
<html lang="en" dir="ltr">
<head>
<meta charset="utf-8">
<title>Test</title>
</head>
<style media="screen">
.form-question {
display: flex;
flex-direction: column;
justify-content: center;
margin: 0 0 3rem;
min-height: 3rem;
}
.form-question__title {
color: #342357;
font-size: 1.5rem;
padding: 1rem;
}
.input-container {
border-bottom: solid 2px #333333;
}
.input-container input {
border: none;
box-sizing: border-box;
outline: 0;
padding: .75rem;
width: 100%;
}
</style>
<body>
<div class="form-question">
<div class="form-question__title">
<span>Effective Date</span>
</div>
<div class="input-container">
<input id="effective-date" type="date" name="effective-date" minlength="1" maxlength="64" placeholder=" " autocomplete="nope" required="required"></input>
<span class="bar"></span>
</div>
</div>
</body>
</html>
首选 CSS 解决方案,但欢迎使用 javascript,请不要使用 jQuery。
提前致谢!
【问题讨论】:
-
目前还没有浏览器公开 API 用于在原生
input[type="date"]上设置样式或操作日历。另外,请注意一些较旧的浏览器(例如 IE)没有本机日期选择器,并且会回退到纯文本输入。移动浏览器也可能有不同的 UI(例如,如果您在 iOS 上默认展开日历,它可能会占据整个屏幕)。所以我建议你要么把默认的日历行为留给浏览器,要么使用一些第三方的日期时间选择器。 -
@evenstar 感谢您的澄清!我确实找到了this,这基本上是同一个问题并且确实解决了我的问题(至少在 Chrome 上)。只需将日历选择器图标设置为输入的完整高度和宽度!
标签: javascript html css