js+css实现投票调查百分百显示柱状图动画效果代码
代码语言:html
所属分类:其他
代码描述:js+css实现投票调查百分百显示柱状图动画效果代码
代码标签: js css 投票 调查 百分百 显示 柱状图 动画
下面为部分代码预览,完整代码请点击下载或在bfwstudio webide中打开
<!DOCTYPE html>
<html lang="en" >
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1">
<style>
@import url("https://fonts.googleapis.com/css2?family=Heebo:wght@100..900&display=swap");
:root {
--canvas: 220;
--bg: hsl(var(--canvas), 15%, 22%);
--fg: hsl(var(--canvas), 39%, 95%);
--link: hsl(var(--canvas), 90%, 80%);
--linkh: hsl(150, 95%, 70%);
--wgt: 200;
}
body,
html {
font-family: heebo, sans-serif;
color: var(--fg);
background: var(--bg);
font-weight: var(--wgt);
padding: 0 0 50px;
display: grid;
place-items: center;
height: 100%;
}
a {
color: var(--link);
text-decoration: none;
font-weight: 450;
transition: all 0.3s ease;
}
a:hover,
a:focus,
a:active {
color: var(--linkh);
}
button {
background: hsl(var(--canvas), 10%, 10%);
color: inherit;
border: none;
border-radius: 0.5em;
padding: 0.25em 0.5em;
font-family: inherit;
font-size: inherit;
}
.social-icon {
stroke-width: 1.25;
stroke: currentColor;
fill: transparent;
background: transparent;
stroke-linecap: round;
stroke-linejoin: round;
position: fixed;
bottom: 10px;
right: 10px;
width: 24px;
height: 24px;
z-index: 10;
animation: iconsLoad 10s ease both 5s;
}
.social-icon path {
fill: none;
}
.social-icon.twitter {
right: 40px;
animation-delay: 4s;
}
.social-icon.codepen {
bottom: 10px;
right: 80px;
width: max-content;
animation-delay: 3s;
}
@keyframes iconsLoad {
from {
opacity: 0;
transform: translateY(-20px);
}
to {
opacity: 1;
transform: translateY(0px);
}
}
:root {
/* vars */
--post-bg: rgb(14, 14, 17);
--t: .4s;
--ease: linear(0,.005,.02 2.2%,.045,.081 4.9%,.16 7.3%,.465 16.2%,.561,.642,.713 25.8%,.773,.825 32.7%,.868 36.5%,.905 40.9%,.935 45.7%,.958 51.1%,.975 57.4%,.986 64.4%,.993 73.1%,.997 84.1%,.999);
--ease-bar: linear(
0, 0.005, 0.02, 0.045, 0.081 5%, 0.16 7.6%, 0.463 16.6%, 0.558, 0.639, 0.709,
0.769, 0.82 33.3%, 0.863 37.1%, 0.902 41.6%, 0.932 46.5%, 0.956 51.9%,
0.973 58.2%, 0.985 65.3%, 0.992 73.8%, 0.997 84.7%, 0.999
);
--trans: all var(--t) var(--ease);
--star-color: 210deg;
--star-time: 7s;
--star-ease: cubic-bezier(0.75, 0, 0.25, 1);
}
.post {
padding: 1.5rem 1rem 2rem;
padding-left: 3rem;
border-bottom: 1px solid hsl(0deg 0% 100% / 10%);
}
.poll-details {
font-size: 0.75rem;
font-weight: 400;
color: hsl(240deg 15.6% 78.63% / 65%);
}
.poll-choices {
display: flex;
flex-direction: column;
gap: 0.5rem;
}
.poll-choice label {
padding-inline: 1rem;
display: flex;
justify-content: space-between;
border-radius: 0.5rem;
border: 1px solid rgb(76, 76, 92);
position: relative;
isolation: isolate;
}
.poll-choice .poll-label {
gap: 0.5rem;
overflow: hidden;
width: 100%;
min-height: 44px;
}
.poll-choice .poll-percent,
.poll-choice .poll-label {
display: flex;
align-items: center;
font-weight: 400;
margin: 0;
z-index: 1;
}
.poll-choice .poll-percent {
opacity: 0;
translate: 100% 0;
width: 2rem;
text-align: right;
justify-content: end;
transition: all calc(var(--t)*3) var(--ease-bar);
}
.poll-choice .answer {
width: 100%;
overflow: hidden;
white-space: nowrap;
text-overflow: ellipsis;
display: block;
filter: none;
transition: var(--trans);
}
.poll-choice .poll-label .radio {
display: flex;
transition: var(--trans);
overflow: hidden;
flex: 0 0 16px;
}
.poll-result {
position: absolute;
inset: -1px;
border-top-left-radius: 0.5rem;
border-bottom-left-radius: 0.5rem;
mask-size: cover;
background-size: 0% 100%;
background-position: 0% 0%;
transition: opacity var(--t) var(--ease);
opacity: 0;
}
.poll-result:before,
.poll-result:after {
content: "";
position: absolute;
inset: 0;
border-radius: calc(0.5rem);
mix-blend-mode: hard-light;
background-image: linear-gradient(90deg, hsl(240deg 10% 90% / 50%), hsl(240deg 10% 90% / 90%) 80%);
background-size: inherit;
background-repeat: no-repeat;
background-position: inherit;
transition: all calc(var(--t)*3) var(--ease-bar);
}
.poll-result:after {
inset: 1px;
border-radius: calc(0.5rem - 1px);
background: rgb(14 14 17 / 50%);
background-size: calc( 100% - 2px ) 100%;
opacity: 1;
z-index: 1;
mix-blend-mode: unset;
}
.poll-result .star {
position: absolute;
left: var(--percent, 0%);
top: 50%;
translate: -50% -50%;
width: auto;
height: 90%;
transition: left calc(var(--t)*3) var(--ease-bar), opacity calc(var(--t)*3) var(--ease-bar);
mix-blend-mode: plus-lighter;
filter: drop-shadow(0 0 3px hsl(var(--star-color) 100% 60% / 70%)) drop-shadow(0 0 8px hsl(var(--star-color) 100% 60% / 70%));
z-index: 2;
opacity: 0;
}
.poll-result .star:after {
content: "";
position: absolute;
left: 50%;
top: 50%;
translate: -50% -50%;
height: 120%;
aspect-ratio: 1/10;
border-radius: 100%;.........完整代码请登录后点击上方下载按钮下载查看
网友评论0