的联动特性…">
当前位置:首页 > CSS

css制作开关

2026-02-26 23:13:20CSS

使用纯CSS制作开关

通过CSS的checkbox hack技术可以实现纯CSS开关效果。核心思路是利用<label><input type="checkbox">的联动特性。

<label class="switch">
  <input type="checkbox">
  <span class="slider"></span>
</label>
.switch {
  position: relative;
  display: inline-block;
  width: 60px;
  height: 34px;
}

.switch input {
  opacity: 0;
  width: 0;
  height: 0;
}

.slider {
  position: absolute;
  cursor: pointer;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: #ccc;
  transition: .4s;
  border-radius: 34px;
}

.slider:before {
  position: absolute;
  content: "";
  height: 26px;
  width: 26px;
  left: 4px;
  bottom: 4px;
  background-color: white;
  transition: .4s;
  border-radius: 50%;
}

input:checked + .slider {
  background-color: #2196F3;
}

input:checked + .slider:before {
  transform: translateX(26px);
}

添加动画效果的开关

为开关添加更流畅的过渡效果,可以调整transition属性:

.slider {
  transition: all 0.4s cubic-bezier(0.68, -0.55, 0.265, 1.55);
}

不同风格的开关设计

  1. 方形开关

    css制作开关

    .slider {
    border-radius: 0;
    }
    .slider:before {
    border-radius: 0;
    }
  2. iOS风格开关

    .slider {
    background-color: #e9e9eb;
    }
    input:checked + .slider {
    background-color: #34c759;
    }
  3. Material Design风格

    css制作开关

    .slider {
    box-shadow: 0 2px 5px rgba(0,0,0,0.2);
    }

禁用状态样式

为开关添加禁用状态样式:

input:disabled + .slider {
  opacity: 0.5;
  cursor: not-allowed;
}

响应式尺寸调整

通过CSS变量实现尺寸可配置:

:root {
  --switch-width: 60px;
  --switch-height: 34px;
}

.switch {
  width: var(--switch-width);
  height: var(--switch-height);
}

.slider:before {
  height: calc(var(--switch-height) - 8px);
  width: calc(var(--switch-height) - 8px);
}

input:checked + .slider:before {
  transform: translateX(calc(var(--switch-width) - var(--switch-height)));
}

标签: css
分享给朋友:

相关文章

css制作下拉导航条

css制作下拉导航条

使用纯CSS制作下拉导航条 HTML结构部分需要包含导航主菜单和子菜单项,通常使用嵌套的无序列表(<ul>和<li>)实现: <nav class="dropdown-…

div和css制作

div和css制作

使用 div 和 CSS 制作网页布局 HTML 结构 通过 div 标签划分页面区域,例如头部、主体、侧边栏和页脚: <div class="container"> <…

如何制作css导航菜单

如何制作css导航菜单

创建基本HTML结构 导航菜单的基础是HTML结构。使用<nav>标签包裹无序列表<ul>,每个菜单项用<li>标签表示,链接用<a>标签。 <…

css 制作购物网站

css 制作购物网站

布局设计 使用CSS Grid或Flexbox创建响应式布局。Grid适合整体页面结构,Flexbox适合局部组件排列。定义网格模板区域,如头部、导航、商品展示区、侧边栏和页脚。 .containe…

css菜单制作

css菜单制作

CSS 菜单制作方法 水平导航菜单 使用 display: inline-block 或 flexbox 可以轻松创建水平导航菜单。以下是一个基本示例: <nav> <ul c…

css字体制作

css字体制作

使用 @font-face 自定义字体 通过 @font-face 规则引入自定义字体文件(如 .woff, .woff2, .ttf)。需定义字体名称和文件路径: @font-face {…