jQuery Auto-Suggestion in Formular übernehmen
lima-city → Forum → Die eigene Homepage → HTML, CSS & Javascript
auto
code
datei
dynamisch erstellten elementen
element
ergebnis
formular
funktion
gecko
header
index
inhalt
liste
nehmen
suche
suggestion
test
text
type
url
-
Hallo
ich versuche für ein Such-Formular die (Google-) Auto-Suggestion zu verwenden,
bekomme auch Ergebnisse, aber schaffe es nicht ein Ergebnis zu übernehmen
Die Auto-Suggestion Ergebnisse werden dynamisch in einer ul / li Liste ausgegeben
bei einem Test, den Inhalt eines <li> Elements per jQuery click Funktion in Variable zu holen
... da klappt es 1A
Aber bei mit <li> Elemente aus Auto-Suggestion klappt es nicht ?!? .... ???
hier ist mein Code:
Datei: index.php
<?php // ---------------------------------------------------- header('Content-type: text/html; charset=utf-8'); if (!empty($_REQUEST['q'])) { $go_query = trim($_REQUEST['q']); } else { $go_query = ''; } // ---------------------------------------------------- ?> <html> <head> <title>Suggestions</title> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <script type="text/javascript" src="http://code.jquery.com/jquery-latest.min.js"></script> <script type="text/javascript"> $('document').ready(function() { text_prompt = 'Suche eingeben'; // Add initial text to textbox if($('#tx').val() == '') { $('#tx').val(text_prompt) } // When clicked remove text $('#tx').click(function(){ if($('#tx').val() == '' || $('#tx').val() == text_prompt) { $('#tx').val('') } }) // When text input loses focus $('#tx').blur(function(){ if($('#tx').val() == '') { $('#tx').val(text_prompt) } }) $('#tx').keyup(function() { $('#search_dd').html(get_json($('#tx').val())); }) function get_json(text) { // To avoid sending an empty query if(text != '') { $('#search_dd').slideDown('fast', function(){ var query = encodeURI(text); var misec = new Date().getTime(); url = 'suggestions1.php?q=' + query + "&m=" + misec + ""; $.get(url, function(data) { $('#search_dd').html(data) }); }) } else { $('#search_dd').slideUp('fast', function(){ $('#search_dd').html(''); }) } } function hi_mal(text) { $('#mal').html(text) } $("#test li").click(function() { var testtxt = $(this).text(); // alert("Auswahl: "+ testtxt); $('#mal').empty().text(testtxt); $('#tx').val(testtxt); }); $("#sug li").click(function() { var sugtxt = $(this).text(); // alert("Auswahl: "+ sugtxt); $('#mal').empty().text(sugtxt); $('#tx').val(sugtxt); }); }); </script> <style type="text/css"> body { font-family: Verdana, Arial, Helvetica, sans-serif; font-size: 14px; background:#FFFFFF; color:#000000; } div#search_dd { background: #FFF; border: 1px solid gray; display: none; margin:8px; width: 500px; height: 260px; overflow-y: scroll; } label { margin: 4px 4px 8px 12px; padding: 2px; font-size: 12px; font-style: italic; } #mal { background: purple; color: yellow; margin:8px; width: 500px; height: 36px; text-align: center; } form { width: 520px; margin: 20px auto; padding: 6px; font-size:14px; background:#DEDEDE; } input#tx { width: 210px; font-size:16px; } #search_dd ul { list-style-type: none; list-style: none; margin: 0; padding: 0; } #search_dd ul#sug li { list-style: none; padding: 2px 2px 2px 10px; } .bgdark { background: #EEEEEE; } .bglight { background: #FFFFFF; } </style> </head> <body> <br /> <br /> <br /> <form> <label>Bitte Suche eingeben:</label> <input id="tx" name="q" value="<?php echo $go_query; ?>" /> OK: <input type="submit" name="go" value="SUCHEN"> <div id="search_dd"></div> <div id="mal"> </div> </form> <br /> <br /> <?php // --------------------------------- if (!empty($go_query)) { echo "<h2>Suche: ".$go_query."</h2>\n"; } else { echo "<p>Bitte zuerst Suchwort(e) eingeben</p>\n"; } // --------------------------------- ?> <br /> <br /> <p>Test Liste</p> <ul id="test"> <li>Eins</li> <li>Zwei</li> <li>Drei</li> <li>Vier</li> </ul> <br /> <br /> <br /> </body> </html>
Datei: suggestions1.php
<?php // ---------------------------------------------------------- header('Content-type: text/html; charset=utf-8'); // ---------------------------------------------------------- class Suggestions { public static function return_list($query) { $lang = 'de'; $url = 'http://suggestqueries.google.com/complete/search?output=firefox&client=firefox&hl=' . $lang . '&q=' . urlencode($query); $ch = curl_init($url); curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, 10); curl_setopt($ch, CURLOPT_TIMEOUT, 10); curl_setopt($ch, CURLOPT_RETURNTRANSFER, true); curl_setopt($ch, CURLOPT_USERAGENT, "Mozilla/5.0 (Windows NT 6.1; WOW64; rv:20.0) Gecko/20100101 Firefox/20.0"); $data = curl_exec($ch); curl_close($ch); $suggestions = json_decode($data, true); echo "\n"; echo "\t".'<ul id="sug">'."\n"; foreach ($suggestions[1] as $index => $s) { if ($index % 2) { $cssclass = 'bgdark'; } else { $cssclass = 'bglight'; } echo "\t\t".'<li class="'.$cssclass.'">' . $s . '</li>'."\n"; } echo "\t".'</ul>'."\n"; } } // ---------------------------------------------------------- $query_str = $_GET['q']; echo Suggestions::return_list($query_str); // ---------------------------------------------------------- ?>
bei Klick auf <li> Elemente von
klappt es<ul id="test">
aber bei Klick auf <li> Elemente von
klappt es nicht ... ?!? ... ???<ul id="sug">
Wie bekomme ich es hin, das es mit diesen "dynamisch" erstellten <li> Elementen funktioniert ??
Wenn man auf ein <li> Element aus der <ul id="sug"> Liste klickt,
dann soll der vorgeschlagene Suchbegriff in das Formular <input> Feld übernommen werden.
-
Diskutiere mit und stelle Fragen: Jetzt kostenlos anmelden!
lima-city: Gratis werbefreier Webspace für deine eigene Homepage
-
hi,
ich nehme mal stark an das es an dem eventhandler "click" liegt.
um die events auch für nachträglich hinzugefügte inhalte nutzbar zu machen solltest du die dafür vorgesehenen jquery eventhandler nehmen, siehe "live" oder "bind"... oder aber auch "on" für die neueren jquery versionen...
Beitrag zuletzt geändert: 4.5.2013 20:46:35 von hcms -
hmm,
ich bekomme es nicht hin, weder mit .live oder .bind oder .on
habe jetzt (nach der document.ready Funktion) eingefügt:
function use_sug (sugtxt) { // alert("Auswahl: "+ sugtxt); $('#mal').empty().text(sugtxt); $('#tx').val(sugtxt); }
und in der suggestions1.php bei <li> Element ein onClick eingefügt
echo "\t\t".'<li class="'.$cssclass.'" onClick="use_sug(\''.$s.'\')">' . $s . '</li>'."\n";
damit geht es, aber blöd, wenn man (ich) in einem von jQuery erzeugtem Element
keinen Click-Handler / Event mit jQuery hin bekommt, sondern das "alte" onClick nehmen muss
.... habe echt viel mit it .live oder .bind oder .on ausprobiert, aber nicht zum Laufen bekommen
:(
-
Diskutiere mit und stelle Fragen: Jetzt kostenlos anmelden!
lima-city: Gratis werbefreier Webspace für deine eigene Homepage