CSS之选择器(十一):focus-within

简介: CSS之选择器(十一):focus-within

前言


有些时候,当我们在填写表单的时候,输入框聚焦的时候需要做一些操作,输入框失去焦点的时候也要做一些操作。而这些我们也可以通过CSS来实现。接下来就让我们介绍一下:focus-within这个选择器。


:focus-within


:focus-within:作用当前表单节点处于聚焦状态下的节点。它监听当前节点里是否有表单节点,且该表单节点是否处于聚焦状态。


接下来我们就通过这个选择来实现一些操作。


代码实现


效果如如下:


image.png


代码如下:


<div page>
    <form class="bubble-distribution">
      <h3>Register</h3>
      <div class="accout">
        <input type="text" 
            placeholder="请输入手机或邮箱" 
            pattern="^1[3456789]\d{9}$|^[\w-]+(.[\w-]+)*@[\w-]+(.[\w-]+)+$" required>
        <img src="https://p1-jj.byteimg.com/tos-cn-i-t2oaga2asx/gold-assets/v3/static/img/greeting.1415c1c.png~tplv-t2oaga2asx-image.image">
      </div>
      <div class="password">
        <input type="password" 
            placeholder="请输入密码(6到20位字符)" 
            pattern="^[\dA-Za-z_]{6,20}$" required>
        <img src="https://p1-jj.byteimg.com/tos-cn-i-t2oaga2asx/gold-assets/v3/static/img/blindfold.58ce423.png~tplv-t2oaga2asx-image.image">
      </div>
      <div class="code">
        <input type="text" 
            placeholder="请输入邀请码(6位数字)" 
            pattern="^[\d]{6}$" maxLength="6" required>
        <button type="button">Proving</button>
        <img src="https://p1-jj.byteimg.com/tos-cn-i-t2oaga2asx/gold-assets/v3/static/img/greeting.1415c1c.png~tplv-t2oaga2asx-image.image">
      </div>
      <img src="https://p1-jj.byteimg.com/tos-cn-i-t2oaga2asx/gold-assets/v3/static/img/normal.0447fe9.png~tplv-t2oaga2asx-image.image">
      <ul>
        <li>
          <input id="male" type="radio" name="sex">
          <label for="male">Mr</label>
        </li>
        <li>
          <input id="female" type="radio" name="sex">
          <label for="female">Ms</label>
        </li>
      </ul>
      <button type="button">Create</button>
    </form>
  </div>
复制代码


[page] {
  display: flex;
  justify-content: center;
  padding: 100px;
  background-color: rgba(0, 0, 0, 0.7);
}
.bubble-distribution {
  position: relative;
  margin-top: 50px;
  padding: 25px;
  border-radius: 2px;
  width: 320px;
  background-color: #fff;
  h3 {
    font-size: 16px;
    color: #333;
  }
  div {
    display: flex;
    margin-top: 10px;
  }
  img {
    position: absolute;
    left: 50%;
    bottom: 100%;
    width: 120px;
    margin: 0 0 -20px -60px;
  }
  ul {
    display: flex;
    justify-content: space-between;
    align-items: center;
    height: 30px;
    margin-top: 10px;
    line-height: 30px;
  }
  li {
    position: relative;
    width: 45%;
    transition: all 300ms;
    &:focus-within {
      background: linear-gradient(90deg, #09f 50%, transparent 0) repeat-x,
      linear-gradient(90deg, #09f 50%, transparent 0) repeat-x,
      linear-gradient(0deg, #09f 50%, transparent 0) repeat-y,
      linear-gradient(0deg, #09f 50%, transparent 0) repeat-y;
      background-position: 0 0, 0 100%, 0 0, 100% 0;
      background-size: 8px 1px, 8px 1px, 1px 8px, 1px 8px;
      animation: move 500ms infinite linear;
    }
  }
  input[type=text],
  input[type=password] {
    flex: 1;
    height: 40px;
    padding: 0 10px;
    border: 1px solid #e9e9e9;
    border-radius: 2px;
    outline: none;
    transition: all 300ms;
    &:focus:valid {
      border-color: #09f;
    }
    &:focus:invalid {
      border-color: #f66;
    }
  }
  input[type=radio] {
    position: absolute;
    width: 0;
    height: 0;
    &:checked + label {
      border: 3px solid transparent;
      background-color: #09f;
      color: #fff;
    }
  }
  label {
    display: block;
    text-align: center;
    border-bottom: 1px solid #ccc;
    background-clip: padding-box;
    cursor: pointer;
    transition: all 300ms;
  }
  button {
    overflow: hidden;
    width: 100%;
    height: 40px;
    margin-top: 10px;
    border: none;
    border-radius: 2px;
    outline: none;
    color: #fff;
    background-color: #09f;
    cursor: pointer;
    transition: all 300ms;
  }
  .accout,
  .password,
  .code {
    img {
      display: none;
      margin-bottom: -27px;
    }
    &:focus-within {
      img {
        display: block;
      }
      & ~ img {
        display: none;
      }
    }
  }
  .code {
    display: flex;
    justify-content: space-between;
    button {
      margin-top: 0;
      padding: 0;
    }
    input {
      &:not(:placeholder-shown) {
        width: 70%;
        & + button {
          width: 25%;
        }
      }
      &:placeholder-shown {
        width: 100%;
        & + button {
          width: 0;
          opacity: 0;
        }
      }
    }
  }
}
@keyframes move {
  to {
    background-position: 6% 0, -6% 100%, 0 -6%, 100% 6%;
  }
}
复制代码


好,今天就到这里了,今天努力的你依然是最棒的,Bye Bye!!!

相关文章
|
4月前
|
前端开发
CSS:高级选择器
CSS:高级选择器
60 1
|
4月前
|
前端开发 JavaScript
CSS:基础选择器
CSS:基础选择器
62 1
|
2月前
|
存储 移动开发 前端开发
高效的 HTML 与 CSS 编写技巧,涵盖语义化标签、文档结构优化、CSS 预处理、模块化设计、选择器优化、CSS 变量、媒体查询等内容
本文深入探讨了高效的 HTML 与 CSS 编写技巧,涵盖语义化标签、文档结构优化、CSS 预处理、模块化设计、选择器优化、CSS 变量、媒体查询等内容,旨在提升开发效率、网站性能和用户体验。
58 5
|
2月前
|
前端开发 JavaScript UED
深入理解与应用 CSS 伪类选择器
【10月更文挑战第23天】通过以上对 CSS 伪类选择器的深入探讨,我们可以更好地理解和应用它们,为网页设计和开发带来更丰富、更灵活的样式效果。同时,要注意在实际应用中根据具体情况合理选择和使用伪类选择器,以达到最佳的设计效果和用户体验。
63 2
|
4月前
|
前端开发 JavaScript 容器
谁动了我的选择器?深入理解CSS选择器优先级
该文章详细解释了CSS选择器的工作原理,包括不同种类选择器的权重计算规则,并通过实例说明了如何解决样式冲突问题,确保所需的样式能够正确应用到目标元素上。
|
4月前
|
前端开发
前端基础(四)_CSS层叠样式表_什么是css_css样式的引入方式_样式表的优先级_样式选择器
本文详细介绍了CSS(层叠样式表)的基本概念、语法规则、引入方式、样式表的优先级和样式选择器。文章解释了CSS的作用,展示了如何在HTML中通过行内样式、内部样式和外部样式引入CSS,讨论了不同CSS选择器的优先级和如何确定最终的样式应用。此外,还强调了使用`!important`规则时的优先级高于行内样式。
147 1
|
3月前
|
前端开发
CSS常见的选择器
CSS常见的选择器
29 0
|
4月前
|
前端开发 JavaScript
【CSS】选择器
【CSS】选择器
|
5月前
|
前端开发
CSS3选择器
【8月更文挑战第23天】CSS3选择器。
40 1
|
5月前
|
前端开发
CSS中的层级选择器&伪类选择器和伪元素选择器
CSS中的层级选择器&伪类选择器和伪元素选择器