Diskuze: podbarveni vypisu z DB na onClick
V předchozím kvízu, Online test znalostí PHP, jsme si ověřili nabyté zkušenosti z kurzu.
Člen
Zobrazeno 7 zpráv z 7.
//= Settings::TRACKING_CODE_B ?> //= Settings::TRACKING_CODE ?>
V předchozím kvízu, Online test znalostí PHP, jsme si ověřili nabyté zkušenosti z kurzu.
Ahoj, pro vložení kódu je zde tlačítko code. Bez něj se to nedá luštit.
a když to JS hodíš až za PHP?
nee asi jsem napsal blbost, nevšiml jsem si události window.onload(),
sorry
ten kód se nadá rozluštit .... ale pokud jsi to udělal u normální html tabulky, tak v čem je problém u tabulky echované z PHP ?
sorry, tady je vypis uz pomoci "code" davam tady jen kod pouziteho java scriptu a php vypisu z databaze, ostatni html je zbytecne, diky moc
<script type="text/javascript">
window.onload=function(){
var tfrow = document.getElementById('confirm').rows.length;
var tbRow=[];
for (var i=1;i<tfrow;i++) {
tbRow[i]=document.getElementById('confirm').rows[i];
tbRow[i].ondblclick = function(){
this.style.backgroundColor = 'pink';
};
tbRow[i].onclick = function() {
this.style.backgroundColor = '#90ee90';
};
}
};
</script>
<?php
$db = mysql_connect($servername, $username, $password, $dbname);
if (!$db) {
die("Connection failed: " . mysql_connect_error());
}
mysql_select_db("dbname",$db);
$result = mysql_query("SELECT * FROM mydb_book",$db);
$radku = mysql_num_rows($result);
for($i=0;$i<$radku;$i++)
{
printf("<table id='confirm' class='tab2'><tr>\n");
printf("<td> %s</td>\n", mysql_result($result,$i,"id"));
printf("<td> %s</td>\n", mysql_result($result,$i,"datum"));
printf("<td> %s</td>\n", mysql_result($result,$i,"nazev"));
printf("<td> %s</td>\n", mysql_result($result,$i,"autor"));
printf("<td> %s</td>\n", mysql_result($result,$i,"text"));
printf("</table>
\n");
}
mysql_close($db);
?>
Koukni se do DOM v chromu či tak, jestli tam ta tabulka opravdu je tak, jak má být.
Tak já vidím třeba chybu ve výpisu tabulky.
Když ti databáze vrátí třeba 3 záznamy, tak ti ten cyklus podle mě
vyhodí toto:
<table id='confirm' class='tab2'>
<tr>
<td>id</td>
<td>datum</td>
<td>nazev</td>
<td>autor</td>
<td>text</td>
</tr>
</table>
<table id='confirm' class='tab2'>
<tr>
<td>id</td>
<td>datum</td>
<td>nazev</td>
<td>autor</td>
<td>text</td>
</tr>
</table>
<table id='confirm' class='tab2'>
<tr>
<td>id</td>
<td>datum</td>
<td>nazev</td>
<td>autor</td>
<td>text</td>
</tr>
</table>
což je špatně ... zřejmě by to asi mělo být jen v jedné tabulce, ne ? tímpádem máš na stránce duplicitní IDčka a JS na tom spadne, protože nemůže být více stejných id na stránce.
Zobrazeno 7 zpráv z 7.