原生js实现日期与时间选择器效果代码
代码语言:html
所属分类:选择器
代码描述:原生js实现日期与时间选择器效果代码
下面为部分代码预览,完整代码请点击下载或在bfwstudio webide中打开
<!DOCTYPE html>
<html lang="en" >
<head>
<meta charset="UTF-8">
<style>
body{
padding: 50px;
}
html {
box-sizing: border-box;
font-family: sans-serif;
font-size: 1em;
}
*,
*::before,
*::after {
box-sizing: inherit;
}
/* *********************************** */
.date-picker {
--control-size: 1.7rem;
width: min-content;
display: grid;
grid-template-columns: repeat(3,min-content);
grid-auto-rows: min-content;
gap: calc(0.2 * var(--control-size));
position: relative;
}
.date-picker button,
.date-picker input {
font-size: var(--control-size);
}
.date-picker > button:focus {
outline: 2px dashed blue;
outline-offset: 1px;
}
.date-picker > .back-btn {
padding: 0px;
position: relative;
}
.date-picker > .back-btn:before {
content: "";
display: block;
width: var(--control-size);
height: var(--control-size);
background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' version='1.1' xmlns:xlink='http://www.w3.org/1999/xlink' xmlns:svgjs='http://svgjs.com/svgjs' viewBox='0 0 16 16' width='16' height='16'%3E%3Cg transform='matrix(0.6666666666666666,0,0,0.6666666666666666,0,0)'%3E%3Cpath d='M21.016.531A2,2,0,0,0,19,.563L2.929,10.288a2,2,0,0,0,0,3.422L19,23.436a2,2,0,0,0,3.035-1.711V2.274A2,2,0,0,0,21.016.531Z' fill='%23000000' stroke='none' stroke-linecap='round' stroke-linejoin='round' stroke-width='0'%3E%3C/path%3E%3C/g%3E%3C/svg%3E") no-repeat 50% 50% / calc(0.7 * var(--control-size));
}
.date-picker > .back-btn:disabled {
cursor: not-allowed;
}
.date-picker > .back-btn:disabled:before {
opacity: 0.1;
}
.date-picker > .forward-btn {
padding: 0px;
position: relative;
}
.date-picker > .forward-btn:before {
content: "";
display: block;
width: var(--control-size);
height: var(--control-size);
position: relative;
background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' version='1.1' xmlns:xlink='http://www.w3.org/1999/xlink' xmlns:svgjs='http://svgjs.com/svgjs' viewBox='0 0 16 16' width='16' height='16'%3E%3Cg transform='matrix(0.6666666666666666,0,0,0.6666666666666666,0,0)'%3E%3Cpath d='M21.058,10.289,5.014.564A2,2,0,0,0,1.978,2.275v19.45a2,2,0,0,0,3.037,1.711l16.043-9.725a2,2,0,0,0,0-3.422Z' fill='%23000000' stroke='none' stroke-linecap='round' stroke-linejoin='round' stroke-width='0'%3E%3C/path%3E%3C/g%3E%3C/svg%3E") 50% 50% / calc(0.7 * var(--control-size)) no-repeat;
}
.date-picker > .forward-btn:disabled {
cursor: not-allowed;
}
.date-picker > .forward-btn:disabled:before {
opacity: 0.1;
}
.date-picker > .date-input {
position: relative;
height: 100%;
align-self: center;
}
.date-picker > .date-input > input[type=text] {
cursor: default;
display: block;
width: calc(10 * var(--control-size));
height: 100%;
padding-left: 0.3em;
z-index: 2;
}
.date-picker > .date-input.focused > input[type=text] {
outline: 2px dashed blue;
outline-offset: 1px;
}
.date-picker > .date-input::after {
content: "";
position: absolute;
width: calc(1.5 * var(--control-size));
height: 100%;
top: 0px;
right: 0px;
z-index: 1;
background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' version='1.1' .........完整代码请登录后点击上方下载按钮下载查看
















网友评论0