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
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226<?
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"
>
$('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
12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849<?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:
12345function
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
1echo
"\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