【问题标题】:Style <label> when nested <input> is invalid嵌套 <input> 时的样式 <label> 无效
【发布时间】:2021-12-28 19:51:04
【问题描述】:

理想情况下,我希望标签文本在输入值无效时改变颜色。

例子:

<form>
  <label>
    Enter an email address:
    <input type="email">
  </label>
</form>

理想情况下,我会使用这样的东西,但它不起作用,因为它是无效的 &lt;input&gt;,而不是 &lt;label&gt;

label:invalid {
  color: red
}

我以这种方式设置了我的&lt;label&gt;&lt;input&gt;,这样我就不需要将id 传递到这些元素中。

与此类似,但 &lt;label&gt;&lt;input&gt; 不是兄弟姐妹:https://pretagteam.com/question/change-the-colour-of-a-label-when-an-input-is-invalid

【问题讨论】:

  • 我想它确实回答了这个问题,但我希望避免使用 JS。 “没有 JavaScript,事情就会变得困难”。我可能只需要重新设计我的表单组件。谢谢。

标签: html css css-selectors


【解决方案1】:

您可以通过使用变量名称label 引用标签元素并根据您的喜好操作其属性来解决此问题。

let label = document.querySeletor("label")
 
if (!isValid(email){
   label.style.Color = "red"
}

但是,您可以创建一个检查输入验证的函数 例如由正则表达式组成的函数isValid(email)

上述是否回答了您的问题?

【讨论】:

  • 出于可扩展性和性能的原因,我尝试使用 CSS。
猜你喜欢
  • 2011-01-21
  • 2022-06-15
  • 2017-12-05
  • 2021-01-02
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2012-06-01
相关资源
最近更新 更多