Wie kann ich dafür sorgen, dass ein HTML-Textfeld im leeren Zustand einen Hinweis anzeigt?


210

Ich möchte, dass das Suchfeld auf meiner Webseite das Wort "Suche" in grauer Kursivschrift anzeigt. Wenn das Feld den Fokus erhält, sollte es wie ein leeres Textfeld aussehen. Wenn bereits Text enthalten ist, sollte der Text normal angezeigt werden (schwarz, nicht kursiv). Dies hilft mir, Unordnung zu vermeiden, indem ich das Etikett entferne.

Übrigens, dies ist eine On-Page- Ajax- Suche, daher gibt es keine Schaltfläche.


4
Seit die Frage gestellt wurde, wird das HTML5-Platzhalterattribut von allen Browsern unterstützt.
Jasen

Hallo Michael. Wären Sie bereit, die akzeptierte Antwort auf dieser Seite zu ändern? Es scheint einen klaren Gewinner zu geben, der sich von der akzeptierten Antwort unterscheidet.
null

Das Problem mit einer JavaScript-Lösung ist, dass nicht jeder JavaScript aktiviert hat. Der Platzhalter verschwindet nicht, wenn das Textfeld den Fokus erhält, wenn ein Browser-Plug-In wie NoScript verwendet wird (sehr praktisch für Entwickler, die es installiert haben). Die Platzhalteroption ist die robusteste Lösung.
Sablefoste

Antworten:


365

Wenn Sie diese Funktion nur für neuere Browser verwenden möchten, können Sie auch die Unterstützung verwenden, die das Platzhalterattribut von HTML 5 bietet :

<input name="email" placeholder="Email Address">

In Ermangelung von Stilen sieht dies in Chrome folgendermaßen aus:

Geben Sie hier die Bildbeschreibung ein

Sie können Demos hier und in HTML5 Placeholder Styling mit CSS ausprobieren .

Überprüfen Sie unbedingt die Browserkompatibilität dieser Funktion . Unterstützung in Firefox wurde in 3.7 hinzugefügt. Chrome ist in Ordnung. Internet Explorer hat nur in 10 Unterstützung hinzugefügt. Wenn Sie auf einen Browser abzielen, der keine Eingabeplatzhalter unterstützt, können Sie ein jQuery-Plugin namens jQuery HTML5 Placeholder verwenden und dann einfach den folgenden JavaScript-Code hinzufügen, um ihn zu aktivieren.

$('input[placeholder], textarea[placeholder]').placeholder();

@Duke, es funktioniert in Fx3.7 +, (Safari / Chrome) und Opera. IE9 unterstützt es nicht, also denke ich, IE8 auch nicht.
Alessandro Vermeulen

Ja, ich habe heute gerade herausgefunden, dass FF3.6 dies nicht unterstützt.
Drew Noakes

Ich denke, es ist wieder bewegt. Ich fand es hier: github.com/mathiasbynens/jquery-placeholder
jocull

Vorsichtsmaßnahme Entwickler "Internet Explorer 10 und 11 zeigen den Platzhalter nicht an, wenn das Feld fokussiert ist, auch wenn das Feld leer ist."
Colonel Panic

92

Dies wird als Textfeld-Wasserzeichen bezeichnet und erfolgt über JavaScript.

oder wenn Sie jQuery verwenden, ein viel besserer Ansatz:


4
Diese zweite Verbindung ist unterbrochen. Dies könnte ähnlich sein: digitalbush.com/projects/watermark-input-plugin
Michael Haren

14
Ich habe einen anderen jQuery-Ansatz gefunden. Dieses Projekt wird gehostet @ code.google.com/p/jquery-watermark
JP Hellemons

4
Das Digitalbrush-Plugin speichert das 'Wasserzeichen' in der Datenbank. Es befindet sich in der Beta- Phase und wurde seit 2007 nicht mehr aktualisiert. Ich empfehle stattdessen, code.google.com/p/jquery-watermark zu verwenden, wie von @JP vorgeschlagen.
Kimball Robinson

1
Ich denke, der Autor der Frage sollte zurückgehen und den Kommentar @JP als beste Antwort markieren.
Randy L

2
Das jQuery-Wasserzeichen-Plugin ist ziemlich einfach, da es den Fall nicht behandelt, in dem die Eingabe mit dem vorgefüllten Wert übereinstimmt. In diesem Fall wird Ihr Eingabetext wieder grau!
atp

41

Sie können den Platzhalter mithilfe des placeholderAttributs in HTML festlegen ( Browserunterstützung ). Das font-styleund colorkann mit CSS geändert werden (obwohl die Browserunterstützung begrenzt ist).

input[type=search]::-webkit-input-placeholder { /* Safari, Chrome(, Opera?) */
 color:gray;
 font-style:italic;
}
input[type=search]:-moz-placeholder { /* Firefox 18- */
 color:gray;
 font-style:italic;
}
input[type=search]::-moz-placeholder { /* Firefox 19+ */
 color:gray;
 font-style:italic;
}
input[type=search]:-ms-input-placeholder { /* IE (10+?) */
 color:gray;
 font-style:italic;
}
<input placeholder="Search" type="search" name="q">


War auf der Suche nach diesem, ta - weitere Informationen diveintohtml5.org/forms.html#placeholder
David Yell

2
Dies sollte nun die akzeptierte Antwort sein. Das Platzhalterattribut wurde möglicherweise nicht allgemein unterstützt, als es ursprünglich im Jahr 2010 veröffentlicht wurde, aber jetzt wird es von allen aktuellen Browsern außer IE8 unterstützt.
JSP64

20

Sie können eine spezielle CSS-Klasse hinzufügen und entfernen und den Eingabewert onfocus/ onblurmit JavaScript ändern :

<input type="text" class="hint" value="Search..."
    onfocus="if (this.className=='hint') { this.className = ''; this.value = ''; }"
    onblur="if (this.value == '') { this.className = 'hint'; this.value = 'Search...'; }">

Geben Sie dann eine Hinweisklasse mit dem gewünschten Stil in Ihrem CSS an, zum Beispiel:

input.hint {
    color: grey;
}

2
Ich habe eine Antwort gepostet, die das Gleiche tut, aber auf bequemere und wartbarere Weise: stackoverflow.com/questions/108207/…
Drew Noakes

6

Der beste Weg ist, Ihre JavaScript-Ereignisse mit einer JavaScript-Bibliothek wie jQuery oder YUI zu verbinden und Ihren Code in eine externe .js-Datei zu legen.

Wenn Sie jedoch eine schnelle und schmutzige Lösung wünschen, ist dies Ihre Inline-HTML-Lösung:

<input type="text" id="textbox" value="Search"
    onclick="if(this.value=='Search'){this.value=''; this.style.color='#000'}" 
    onblur="if(this.value==''){this.value='Search'; this.style.color='#555'}" />

Aktualisiert : Das angeforderte Farbmaterial wurde hinzugefügt.


Dies ist für Suchvorgänge in Ordnung, aber in vielen Fällen möchten Sie nicht, dass Wasserzeichen bei einem Übermittlungsereignis gesendet werden.
Kimball Robinson

@ k.robinson I +1 diese Aussage. Dies war zu diesem Zeitpunkt der schnellste und kompakteste Code. Es könnte feinkörniger mit einem Javascript-Codeblock gelöst werden.
Seb Nilsson

4

Ich habe vor einiger Zeit eine Lösung dafür auf meiner Website veröffentlicht . Um es zu verwenden, importieren Sie eine einzelne .jsDatei:

<script type="text/javascript" src="/hint-textbox.js"></script>

Kommentieren Sie dann alle Eingaben, die Sie mit der CSS-Klasse versehen möchten hintTextbox:

<input type="text" name="email" value="enter email" class="hintTextbox" />

Weitere Informationen und Beispiele finden Sie hier .


1
Aber es ist kaputt. Wenn ich den gleichen Text eingebe, der der Hinweis war, verhält es sich so, als ob keine Eingabe gegeben wurde (wenn ich hinein und dann wieder heraus
gehe

2
@Stephan: Ja, das ist die einzige Einschränkung, die ich kenne. Haben Sie tatsächlich festgestellt, dass dies in der Praxis ein Problem darstellt? Wenn ja, müssen Sie möglicherweise untersuchen, ob ein Div darüber geschichtet und angezeigt / ausgeblendet wird. Dies ist die einfachste Lösung, die ich kenne. Ich verschlechtere mich auch gut, wenn JavaScript deaktiviert ist.
Drew Noakes

Ich wurde durch die Einstellung des Wertes ausgelöst. Ich habe eine kombinierte Notwendigkeit des Vorfüllens mit einem vorhandenen oder Standardwert und einem Hinweis, wenn das Textfeld leer ist
Stephan Eggermont

@Stephan - Ich bin heute tatsächlich auf einen Bedarf dafür gestoßen und schaue mir jQuery-Plugins an. Derjenige, auf den in der akzeptierten Antwort verwiesen wird, hat das gleiche Problem wie ich. Kennen Sie eine Alternative?
Drew Noakes

3

Hier ist ein Funktionsbeispiel mit dem Google Ajax-Bibliothekscache und etwas jQuery-Magie.

Dies wäre das CSS:

<style type="text/stylesheet" media="screen">
    .inputblank { color:gray; }  /* Class to use for blank input */
</style>

Dies wäre der JavaScript-Code:

<script language="javascript"
        type="text/javascript"
        src="http://www.google.com/jsapi">
</script>
<script>
    // Load jQuery
    google.load("jquery", "1");

    google.setOnLoadCallback(function() {
        $("#search_form")
            .submit(function() {
                alert("Submitted. Value= " + $("input:first").val());
                return false;
        });

        $("#keywords")
            .focus(function() {
                if ($(this).val() == 'Search') {
                    $(this)
                    .removeClass('inputblank')
                    .val('');
                }
            })
            .blur(function() {
                if ($(this).val() == '') {
                    $(this)
                    .addClass('inputblank')
                    .val('Search');
                }
            });
    });
</script>

Und das wäre der HTML:

<form id="search_form">
    <fieldset>
        <legend>Search the site</legend>
            <label for="keywords">Keywords:</label>
        <input id="keywords" type="text" class="inputblank" value="Search"/>
    </fieldset>
</form>

Ich hoffe, es reicht aus, um Sie sowohl für die GAJAXLibs als auch für jQuery zu interessieren.




2

Ich fand das jQuery-Plugin jQuery Watermark besser als das in der oberen Antwort aufgeführte. Warum besser? Weil es Passworteingabefelder unterstützt. Das Festlegen der Farbe des Wasserzeichens (oder anderer Attribute) ist so einfach wie das Erstellen einer .watermarkReferenz in Ihrer CSS-Datei.


2

Dies wird als "Wasserzeichen" bezeichnet.

Ich habe das jQuery-Plugin jQuery-Wasserzeichen gefunden, für das im Gegensatz zur ersten Antwort keine zusätzliche Einrichtung erforderlich ist (für die ursprüngliche Antwort ist auch ein spezieller Aufruf erforderlich, bevor das Formular gesendet wird).


2

Verwenden Sie jQuery Form Notifier - es ist eines der beliebtesten jQuery-Plugins und leidet nicht unter den Fehlern, die einige der anderen jQuery-Vorschläge hier aufweisen (z. B. können Sie das Wasserzeichen frei formatieren, ohne sich Sorgen machen zu müssen, ob es im gespeichert wird Datenbank).

jQuery Watermark verwendet einen einzelnen CSS-Stil direkt für die Formularelemente (ich habe festgestellt, dass die auf das Wasserzeichen angewendeten Eigenschaften der CSS-Schriftgröße auch die Textfelder beeinflussen - nicht das, was ich wollte). Das Plus bei jQuery Watermark ist, dass Sie Text per Drag & Drop in Felder ziehen können (jQuery Form Notifier erlaubt dies nicht).

Ein anderer, der von einigen anderen vorgeschlagen wurde (der auf digitalbrush.com), sendet versehentlich den Wasserzeichenwert an Ihr Formular, daher empfehle ich dringend davon ab.


1

Verwenden Sie ein Hintergrundbild, um den Text zu rendern:

 input.foo { }
 input.fooempty { background-image: url("blah.png"); }

Dann müssen Sie nur noch value == 0die richtige Klasse erkennen und anwenden:

 <input class="foo fooempty" value="" type="text" name="bar" />

Und der jQuery-JavaScript-Code sieht folgendermaßen aus:

jQuery(function($)
{
    var target = $("input.foo");
    target.bind("change", function()
    {
        if( target.val().length > 1 )
        {
            target.addClass("fooempty");
        }
        else
        {
            target.removeClass("fooempty");
        }
    });
});

1

Sie könnten leicht ein Feld mit der Aufschrift "Suchen" haben, und wenn der Fokus darauf geändert wird, wird der Text entfernt. Etwas wie das:

<input onfocus="this.value=''" type="text" value="Search" />

Wenn Sie dies tun, verschwindet natürlich der eigene Text des Benutzers, wenn er darauf klickt. Sie möchten also wahrscheinlich etwas Robusteres verwenden:

<input name="keyword_" type="text" size="25"  style="color:#999;" maxlength="128" id="keyword_"
onblur="this.value = this.value || this.defaultValue; this.style.color = '#999';"
onfocus="this.value=''; this.style.color = '#000';"
value="Search Term">

0

Wenn die Seite zum ersten Mal geladen wird, wird im Textfeld die Suche angezeigt, die grau gefärbt ist, wenn Sie dies wünschen.

Wenn das Eingabefeld den Fokus erhält, wählen Sie den gesamten Text im Suchfeld aus, damit der Benutzer einfach mit der Eingabe beginnen kann, wodurch der ausgewählte Text gelöscht wird. Dies funktioniert auch gut, wenn der Benutzer das Suchfeld ein zweites Mal verwenden möchte, da er den vorherigen Text nicht manuell markieren muss, um ihn zu löschen.

<input type="text" value="Search" onfocus="this.select();" />

0

Ich mag die Lösung von "Knowledge Chikuse" - einfach und klar. Sie müssen nur einen Aufruf zum Verwischen hinzufügen, wenn das Laden der Seite fertig ist, wodurch der Anfangszustand festgelegt wird:

$('input[value="text"]').blur();

0

Sie möchten onfocus so etwas zuweisen:

if (this.value == this.defaultValue)
    this.value = ''
this.className = ''

und dies zu verwischen:

if (this.value == '')
    this.value = this.defaultValue
this.className = 'placeholder'

(Sie können etwas Klügeres wie eine Framework-Funktion verwenden, um den Klassennamen zu wechseln, wenn Sie möchten.)

Mit einigen CSS wie diesem:

input.placeholder{
    color: gray;
    font-style: italic;
}

0

Ich verwende eine einfache einzeilige Javascript-Lösung, die hervorragend funktioniert. Hier ist ein Beispiel sowohl für Textbox als auch für Textbereich:

    <textarea onfocus="if (this.value == 'Text') { this.value = ''; }" onblur="if (this.value == '') { this.value = 'Text'; }">Text</textarea>

    <input type="text" value="Text" onfocus="if (this.value == 'Text') { this.value = ''; }" onblur="if (this.value == '') { this.value = 'Text'; }">

Der einzige "Nachteil" besteht darin, bei $ _POST oder in der Javascript-Validierung zu validieren, bevor etwas mit dem Wert des Feldes getan wird. Das heißt, Sie müssen überprüfen, ob der Feldwert nicht "Text" ist.


-1
$('input[value="text"]').focus(function(){ 
if ($(this).attr('class')=='hint') 
{ 
   $(this).removeClass('hint'); 
   $(this).val(''); 
}
});

$('input[value="text"]').blur(function(){
  if($(this).val() == '')
  {
    $(this).addClass('hint');
    $(this).val($(this).attr('title'));
  } 
});

<input type="text" value="" title="Default Watermark Text">

-1

Ein einfaches HTML-Tag "erforderlich" ist nützlich.

<form>
<input type="text" name="test" id="test" required>
<input type="submit" value="enter">
</form>

Es gibt an, dass ein Eingabefeld ausgefüllt werden muss, bevor das Formular gesendet oder die Schaltfläche Senden gesendet wird. Hier ist ein Beispiel


Es ist zwar nützlich, hat aber nichts mit der Frage zu tun.
Quentin

Durch die Nutzung unserer Website bestätigen Sie, dass Sie unsere Cookie-Richtlinie und Datenschutzrichtlinie gelesen und verstanden haben.
Licensed under cc by-sa 3.0 with attribution required.