2

我有一个带有标签覆盖输入的表单。如下图所示

截屏

下面是一个相同的代码示例。

<label for="edit-submitted-name--2">
Name
<span class="form-required" title="This field is required.">*</span>
</label>
<input id="edit-submitted-name--2" class="form-text required" type="text" maxlength="128" size="35" value="" name="submitted[name]">

每次用户关注输入时,我都想使用 jquery 并隐藏标签。标签仅在输入为空或输入未聚焦时才可见。

  $("input").focus(function () {
          //hide the label corresponding to this input
     });

如何使用 jquery 选择与此输入对应的标签?

注意:我无法更改 html 中的任何内容,因为它是由 Drupal 中的模块生成的。

4

3 回答 3

5

占位符属性是这项工作的正确工具:

<input id="edit-submitted-name--2" class="form-text required" type="text" maxlength="128" size="35" placeholder="Name *" name="submitted[name]">

http://www.w3schools.com/html5/att_input_placeholder.asp

但不要忘记无标签输入字段是不好的做法。占位符应被视为提示。它们不是标签的替代品。

于 2012-05-23T20:30:45.280 回答
3

从当前元素中选择上一个元素。

$(this).prev("label").hide();

$(this).prev("label").show();

但是,这不是 label 元素的目的。

于 2012-05-23T20:32:18.350 回答
1

Remy Bach 创建了 Super Labels 可以满足您的需求,我会使用他的代码,但如果您正在寻找稍微不同的东西,那么您可以使用他的代码作为模板。

https://github.com/remybach/jQuery.superLabels

于 2012-05-23T20:31:25.737 回答