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