css按钮选择按钮,CSS构建的材质化元素:开关选择(选项切换)按钮(switch)

CSS

语言:

CSSSCSS

确定

.pure-material-switch {

z-index: 0;

position: relative;

display: inline-block;

color: rgba(var(--pure-material-onsurface-rgb, 0, 0, 0), 0.87);

font-family: var(--pure-material-font, "Roboto", "Segoe UI", BlinkMacSystemFont, system-ui, -apple-system);

font-size: 16px;

line-height: 1.5;

}

/* Input */

.pure-material-switch > input {

appearance: none;

-moz-appearance: none;

-webkit-appearance: none;

z-index: -1;

position: absolute;

right: 6px;

top: -8px;

display: block;

margin: 0;

border-radius: 50%;

width: 40px;

height: 40px;

background-color: rgba(var(--pure-material-onsurface-rgb, 0, 0, 0), 0.38);

outline: none;

opacity: 0;

transform: scale(1);

pointer-events: none;

transition: opacity 0.3s 0.1s, transform 0.2s 0.1s;

}

/* Span */

.pure-material-switch > span {

display: inline-block;

width: 100%;

cursor: pointer;

}

/* Track */

.pure-material-switch > span::before {

content: "";

float: right;

display: inline-block;

margin: 5px 0 5px 10px;

border-radius: 7px;

width: 36px;

height: 14px;

background-color: rgba(var(--pure-material-onsurface-rgb, 0, 0, 0), 0.38);

vertical-align: top;

transition: background-color 0.2s, opacity 0.2s;

}

/* Thumb */

.pure-material-switch > span::after {

content: "";

position: absolute;

top: 2px;

right: 16px;

border-radius: 50%;

width: 20px;

height: 20px;

background-color: rgb(var(--pure-material-onprimary-rgb, 255, 255, 255));

box-shadow: 0 3px 1px -2px rgba(0, 0, 0, 0.2), 0 2px 2px 0 rgba(0, 0, 0, 0.14), 0 1px 5px 0 rgba(0, 0, 0, 0.12);

transition: background-color 0.2s, transform 0.2s;

}

/* Checked */

.pure-material-switch > input:checked {

right: -10px;

background-color: rgb(var(--pure-material-primary-rgb, 33, 150, 243));

}

.pure-material-switch > input:checked + span::before {

background-color: rgba(var(--pure-material-primary-rgb, 33, 150, 243), 0.6);

}

.pure-material-switch > input:checked + span::after {

background-color: rgb(var(--pure-material-primary-rgb, 33, 150, 243));

transform: translateX(16px);

}

/* Hover, Focus */

.pure-material-switch:hover > input {

opacity: 0.04;

}

.pure-material-switch > input:focus {

opacity: 0.12;

}

.pure-material-switch:hover > input:focus {

opacity: 0.16;

}

/* Active */

.pure-material-switch > input:active {

opacity: 1;

transform: scale(0);

transition: transform 0s, opacity 0s;

}

.pure-material-switch > input:active + span::before {

background-color: rgba(var(--pure-material-primary-rgb, 33, 150, 243), 0.6);

}

.pure-material-switch > input:checked:active + span::before {

background-color: rgba(var(--pure-material-onsurface-rgb, 0, 0, 0), 0.38);

}

/* Disabled */

.pure-material-switch > input:disabled {

opacity: 0;

}

.pure-material-switch > input:disabled + span {

color: rgb(var(--pure-material-onsurface-rgb, 0, 0, 0));

opacity: 0.38;

cursor: default;

}

.pure-material-switch > input:disabled + span::before {

background-color: rgba(var(--pure-material-onsurface-rgb, 0, 0, 0), 0.38);

}

.pure-material-switch > input:checked:disabled + span::before {

background-color: rgba(var(--pure-material-primary-rgb, 33, 150, 243), 0.6);

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值