首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >标签不会在输入焦点上转换

标签不会在输入焦点上转换
EN

Stack Overflow用户
提问于 2022-07-13 14:57:35
回答 2查看 170关注 0票数 0

当有人单击输入时,我想转换输入的标签。但它不会改变。

如果我做了.user-input:focus, .user-input:valid,它会更改输入,这意味着它应该与标签一起工作。

代码语言:javascript
运行
复制
.user-input:focus+.user-label,
.user-input:valid+.user-label {
  color: yellow;
  transform: translate(10px, -14px) scale(.8);
}
代码语言:javascript
运行
复制
<div class="container">
  <div class="input-group">
    <label for="user" class="user-label">Username</label>
    <input type="text" name="user" class="user-input" required>
  </div>
</div>

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2022-07-13 15:17:21

  • in css我们只能选择下一个兄弟姐妹,我们不能选择在DOM.
  • so,中选择兄弟姐妹之前的兄弟姐妹。我刚刚在css后面放置了label,以便在输入之前保留标签。

代码语言:javascript
运行
复制
.input-group {
  display: flex;
  flex-direction: row-reverse;
  justify-content: start;
}

代码语言:javascript
运行
复制
.input-group {
  display: flex;
  flex-direction: row-reverse;
  justify-content: start;
}

.user-label {
  transition: 0.5s;
}

.user-input:active+.user-label,
.user-input:focus+.user-label,
.user-input:valid+.user-label {
  color: yellow;
  transform: translate(10px, -14px) scale(.8);
}
代码语言:javascript
运行
复制
<div class="container">
  <div class="input-group">
    <input type="text" name="user" class="user-input" required>
    <label for="user" class="user-label">Username</label>
  </div>
</div>

票数 0
EN

Stack Overflow用户

发布于 2022-07-13 15:25:28

您可以通过稍微更改HTML结构来实现这一点,用label标记切换输入,不能在目标元素之前的div中使用css元素进行选择。

代码语言:javascript
运行
复制
HTML

 <div class="container">
      <div class="input-group">
        <input type="text" name="user" class="user-input" required>
        <label for="user" class="user-label">Username</label>
      </div>
 </div>

CSS

.user-input:focus + .user-label {
  color: yellow;
  transform: translate(10px, -14px) scale(.8);
}
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/72968410

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档