原生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