Gestire gruppi e categorie di link con PHP

MarcoGrazia

Utente Attivo
15 Dic 2009
788
16
18
59
Udine
www.stilisticamente.com
Ciao.
Ho un problema forum :)
Ecco, sto costruendo un sistema di link (una sitografia a fine del sito); questi vengono memorizzati in un database e poi da questo presi da una pagina per mostrarli a chi guarda.
I link in questione sino categorizzati, ovvero esistono link che riguardano il PHP, altri per il MySQL, e altri ancora CSS... eccetera. Quest categorie potete vederle come dei tag.
La questione però è questa, nel mostrarli e quindi per raggrupparli ho usato liste di definizione (DL) in modo da poter raggruppare i link in questo modo:
HTML:
<dl>
  <dt>CSS</dt>
  <dd>...link...</dd>
  <dd>... link ....</dd>
  <dt>Javascript</dt>
  <dd>...link...</dd>
</dl>
Ora detto così sembra semplice e intuitivo, il problema è che non riesco a trovare un metodo semplice in PHP che funzioni, in pratica una volta tirati fuori i record dal database li processo così:
PHP:
        function data($data) {
		$mesi = array('', 'January','February','March','April','May','June','July','August','September','October','November','December');
		$giorno = substr($data, -2);
		$mese = substr($data, 5, 2);
		$anno = substr($data, 0, 4);
	return "{$mesi[$mese]} $giorno, $anno";
	}	//	data()
	
	if ($res) {	//	Esiste una bibliografia
		echo "\n\t\t\t\t<dl>\n";
		$definitionList = '';
		for ($i=0;$i < $len;$i++) {
			$flag[$res[$i]['gruppo']] = false;
		}
		
		for ($i=0;$i < $len;$i++) {
			if (!$flag[$res[$i]['gruppo']]) {
				$definitionList .= "\t<dt itemprop=\"articleSection\"><strong>{$res[$i]['gruppo']}</strong><dt>\n";
				$flag[$res[$i]['gruppo']] = true;
			}
			switch($res[$i]['lingua']) {
				case 'en': case 'en-UK': case 'en-US': $title = 'the browser opens another page (english)'; break;
				case 'it': case 'it-IT': case 'it-CH': $title = 'il browser apre un\'altra pagina (italiano)'; break;
				default: $title = 'the browser opens another page (english)'; break;
			}
			try {
				$st = $handle->prepare('SELECT id, nome, cognome, nickname FROM autori WHERE id = :ident');
				$st->bindParam(':ident', $res[$i]['autore_id'], PDO::PARAM_STR);
				$st->execute();
				$a = false; $a = $st->fetch(PDO::FETCH_ASSOC);
				$st->closeCursor();
			}
			catch (PDOException $e) {
				echo 'Connection failed: (lettura autore)' . $e->getMessage();
			}
			catch (Exception $e) {
				echo 'Connection failed: (lettura autore)' . $e->getMessage();
			}
			$autore = ucfirst($a['nome'] . ' ' . $a['cognome']);
			$data = data($res[$i]['data']);
			$definitionList .= "\t\t\t\t\t\t<dd><a target=\"_blank\" href=\"{$res[$i]['url']}\" title=\"$title\" lang=\"{$res[$i]['lingua']}\"><span itemprop=\"name\">{$res[$i]['testo']}</span></a>. posted by <span itemprop=\"author\" itemscope itemtype=\"http://schema.org/Person\"><cite itemprop=\"name\">$autore</cite></span> <time itemprop=\"dateCreated\" datetime=\"{$res[$i]['data']}\">$data</time></dd>\n";
			//	$definitionList .= ' - ' . var_dump($flag);
		}
		echo "\t\t\t\t\t$definitionList\n\t\t\t\t</dl>\n\n";
	}
Il risultato è questo: http://stilisticamente.biz/bibliography.php sembra perfetto ma non è così.
Il sistema mi pare che mette le classificazioni in ordine casuale e basta pocp per accorgesene, infatti prendo a caso il link che parla di rounded corner che però lo dovrei trovare sotto CSS3 mentre si trova sotto DOM. Nel database appartiene al gruppo CSS3 quindi il problema è nel metodo di scrittura del codice.
Io proprio non so cosa inventarmi al momento anche perché non da errori su cui lavorare il bastardo :incazz2:
Sono quasi certo che il problema è nel metodo a flag ma non so come sostituire il metodo.
 

MarcoGrazia

Utente Attivo
15 Dic 2009
788
16
18
59
Udine
www.stilisticamente.com
Risolto cambiando completamente approccio.
chiedo una queri ordinandola per gruppi, quindi creo un ciclo che mette in <dt>il nome del gruppo</dt> e poi va avanti a inserire link; come cambia il nome del gruppo rispetto al precedente, cambia anche il dato in <dt>.
Siccome la query è ordinata per gruppi appunto, non capiterà mai che un gruppo si ripeta dopo e quindi non capiterà mai che un gruppo si ripeta anche nella definition list, ma saranno perfettamente ordinati.
Più facile a guardare il codice che a spiegarlo :D ecco qui.
PHP:
        //	BIBLIOGRAFIA
	try {
		$st = $handle->prepare('SELECT * FROM biblio ORDER BY gruppo ASC');
		$st->execute();
		$res = false;
		$res = $st->fetchAll(PDO::FETCH_ASSOC);
		$len = $st->rowCount();
		$st->closeCursor();
	}
	catch (PDOException $e) {
		echo 'Connection failed: (salvataggio)' . $e->getMessage();
	}
	catch (Exception $e) {
		echo 'Connection failed: (salvataggio)' . $e->getMessage();
	}

        function data($data) {
		$mesi = array('', 'January','February','March','April','May','June','July','August','September','October','November','December');
		$giorno = substr($data, -2);
		$mese = substr($data, 5, 2);
		$anno = substr($data, 0, 4);
	return "{$mesi[$mese]} $giorno, $anno";
	}	//	data()
	
	if ($res) {	//	Esiste una bibliografia
		$definitionList = "\n\t\t\t\t<dl>\n\t\t\t\t\t<dt itemprop=\"articleSection\"><strong>{$res[0]['gruppo']}</strong></dt>\n";
		$gruppo = $res[0]['gruppo'];
		for ($i = 0; $i < $len; $i++) {
			switch($res[$i]['lingua']) {
				case 'en': case 'en-UK': case 'en-US': $title = 'the browser opens another page (english)'; break;
				case 'it': case 'it-IT': case 'it-CH': $title = 'il browser apre un\'altra pagina (italiano)'; break;
				default: $title = 'the browser opens another page (english)'; break;
			}
			try {
				$st = $handle->prepare('SELECT id, nome, cognome, nickname FROM autori WHERE id = :ident');
				$st->bindParam(':ident', $res[$i]['autore_id'], PDO::PARAM_STR);
				$st->execute();
				$a = false; $a = $st->fetch(PDO::FETCH_ASSOC);
				$st->closeCursor();
			}
			catch (PDOException $e) {
				echo 'Connection failed: (salvataggio)' . $e->getMessage();
			}
			catch (Exception $e) {
				echo 'Connection failed: (salvataggio)' . $e->getMessage();
			}
			$autore = ucfirst($a['nome'] . ' ' . $a['cognome']);
			$data = data($res[$i]['data']);
			
			if ($res[$i]['gruppo'] != $gruppo) {
				$definitionList .= "\n\t\t\t\t\t<dt itemprop=\"articleSection\"><strong>{$res[$i]['gruppo']}</strong></dt>\n";
				$gruppo = $res[$i]['gruppo'];
			}
			$definitionList .= "\t\t\t\t\t\t<dd><a target=\"_blank\" href=\"{$res[$i]['url']}\" title=\"$title\" lang=\"{$res[$i]['lingua']}\"><span itemprop=\"name\">{$res[$i]['testo']}</span></a>. posted by <span itemprop=\"author\" itemscope itemtype=\"http://schema.org/Person\"><cite itemprop=\"name\">$autore</cite></span> <time itemprop=\"dateCreated\" datetime=\"{$res[$i]['data']}\">$data</time></dd>\n";
		}
		echo "\t\t\t\t\t$definitionList\n\t\t\t\t</dl>\n\n";
	}
Fatto!
 
Discussioni simili
Autore Titolo Forum Risposte Data
L Interfaccia grafica per gestire sql server .NET Framework 1
R Plugin per Gestire videocorsi a pagamento WordPress 3
M Come gestire aggiornamenti e modifiche di sito live Content Management System (CMS) 0
S Gestire scelta dropdown con dati da Mysql PHP 2
Tommy03 Gestire dimensioni immagini PHP 4
D Come gestire un singolo checkbox PHP 10
MarcoGrazia Gestire lista campi vuoti in fase di autenticazione jQuery 1
elpirata Gestire permessi accesso alle pagine PHP 3
A [ASP.Net] Gestire il profilo ADMIN in un progetto ASP NET e pattern MVC ASP.NET 0
M [PHP] Come gestire gli utenti online PHP 9
M [php] Come gestire i tags PHP 1
svtmaster professionalità per gestire sito web Offerte e Richieste di Lavoro e/o Collaborazione 4
L [HTML] Gestire movimento GIF HTML e CSS 0
BestSellerMauroTop Software per gestire tanti profili e pagine, e farle crescere in modo autonomo! Annunci servizi di Social Media Marketing 0
W Gestire ccTalk o libreria c++ da php PHP 0
W [PHP] gestire una richiesta curl sul server PHP 0
W Piccolo sistema per gestire alcune periferiche, Java o altro linguaggio? Java 8
bubino8 [WordPress] Gestire SSL (https://) da .htaccess WordPress 9
C [WordPress] Creare e gestire un nuovo sito web WordPress 5
M Gestire ErrorDocument 404 mantenendo lo stesso url Web Server 0
S gestire una tabella mysql PHP 9
R gestire il ritorno di una variabile con success Ajax 2
S Gestire Motion Detection TP-LINK CAMERA NC200 IP Cam e Videosorveglianza 0
A [Javascript] [HTML] Gestire una pagina esterna con 2 iframe Javascript 4
webmachine [PHP] gestire rinnovi PHP 1
P Gestire accesso ad un file xml pubblico PHP 1
D Gestire diversi tipi di pagamento per tipologia di cliente E-Commerce 4
asevenx Cerco plugin per gestire appuntamenti con agenda e campi di selezione WordPress 4
matteoraggi Software per gestire migliaia di permament redirect? SEO e Posizionamento 0
K Gestire response con servlet remota Sviluppo app per Android 1
P Piccolo software per gestire gli utenti. Snippet PHP 5
F Gestire data e ora PHP 6
D Gestire firme digitali con PHP PHP 0
C [Facebook Autolike]Software per gestire più account, mandare like, creare stati, amicizie e altro.. Vendere e Acquistare pubblicita' online 0
D gestire commenti e risposte ... PHP 3
L Gestire password utenti registrati. Quale codifica? PHP 23
asevenx Gestire posizionamento voci sottomenu che si nascondono HTML e CSS 1
N Programma per gestire Cookies secondo disposizioni del Garante Privacy 3/6/2014 G.U. 126 Leggi, Normative e Fisco 0
A Gestire e modificare immagini Java 2
M Gestire la chiusura forzata. Sviluppo app per Android 1
L Sito con doppia lingua. Gestire il cambio PHP 4
felino Wordpress e QTranslate: come gestire i widget WordPress 11
IImanuII Gestire lingua su facebook con php PHP 18
mondrian Gestire un web server su una virtualbox Apache 12
L gestire array per radio-checkbox in ciclo while PHP 2
L Button per gestire JS in WebBrowser di VBNet .NET Framework 0
A gestire errori 400-401-403-404-500 con file htaccess PHP 0
L classe per gestire login in mysql PHP 1
R Gestire sito creato da un altro webmaster HTML e CSS 10
N Gestire i prodotti con php e database PHP 5

Discussioni simili