Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Recensione Samsung Galaxy Z Fold7: un grande salto generazionale
Recensione Samsung Galaxy Z Fold7: un grande salto generazionale
Abbiamo provato per molti giorni il nuovo Z Fold7 di Samsung, un prodotto davvero interessante e costruito nei minimi dettagli. Rispetto al predecessore, cambiano parecchie cose, facendo un salto generazionale importante. Sarà lui il pieghevole di riferimento? Ecco la nostra recensione completa.
The Edge of Fate è Destiny 2.5. E questo è un problema
The Edge of Fate è Destiny 2.5. E questo è un problema
Bungie riesce a costruire una delle campagne più coinvolgenti della serie e introduce cambiamenti profondi al sistema di gioco, tra nuove stat e tier dell’equipaggiamento. Ma con risorse limitate e scelte discutibili, il vero salto evolutivo resta solo un’occasione mancata
Ryzen Threadripper 9980X e 9970X alla prova: AMD Zen 5 al massimo livello
Ryzen Threadripper 9980X e 9970X alla prova: AMD Zen 5 al massimo livello
AMD ha aggiornato l'offerta di CPU HEDT con i Ryzen Threadripper 9000 basati su architettura Zen 5. In questo articolo vediamo come si comportano i modelli con 64 e 32 core 9980X e 9970X. Venduti allo stesso prezzo dei predecessori e compatibili con il medesimo socket, le nuove proposte si candidano a essere ottimi compagni per chi è in cerca di potenza dei calcolo e tante linee PCI Express per workstation grafiche e destinate all'AI.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 15-11-2013, 14:05   #1
cenarius_88
Member
 
Iscritto dal: Nov 2007
Città: Alcamo
Messaggi: 103
[PHP - MYSQL - CSS] Impostazione layout

Salve a tutti...
Sto creando un progetto a scopo didattico su interazione php sql con elementi di "abbellimento" css.

Secondo la mia idea interrogo tramite php e mysql un database dal quale estraggo dei record. per ogni record a questo punto sempre tramite script php genero dei contenuti html/css seguendo un layout particolare... sono riuscito a ottenere il risultato che volevo ad eccezione di un unica parte: l'identificativo (segnalato in rosso)... non ne vuole sapere di andare li dove dico io...

sono sicuro che il problema è in CSS ma non ne vengo a capo...

query sql + script per creazione del contenuto
Codice:
<?php
$conn=mysql_connect("localhost", "username", "pass");
$numrecord=5;
$count=0;
if (!$conn)
{
	die("Connessione a Mysql non riuscita " . mysql_error());
}
$db=mysql_select_db("my_database", $conn);
if (!$db)
{
	die("Connessione al Database non riuscita " . mysql_error());
}

$Risultato=mysql_query("select * from TABELLA", $conn);
if (!$Risultato)
{
die("La tabella selezionata non esiste " . mysql_error());
}

while ($riga=mysql_fetch_array($Risultato))
{
$count++;
echo "<div class='elemento'>";
echo "<div class='immagine'>" . "<a href='" . $riga[4] ."'  target='_blank'>" . "<img class='aspect' src=' " . $riga[4] . "' /> </a> </div>";
echo "<div class='paragrafo'>";
echo $riga[1] . "</br>"; //TITOLO
echo " <h5 class='descrizione'>" .$riga[2]. "</h5></br>"; //DESCRIZIONE

echo "</div>";
echo " <h5 class='identificativo'>" . $riga[3] . "</h5>"; //IDENTIFICATIVO
echo "</div>";
echo "<br/>";

}
?>
CSS
Codice:
div.elemento {
	width:inherit;
	height:160px;
	background-color:#ffB1d5;
	/* Bordi arrotondati */
	border-radius: 0 20px 20px 0;
	-moz-border-radius: 0 20px 20px 0; /* per firefox */
	-webkit-border-radius: 0 20px 20px 0; /* per safari, chrome */
}

div.immagine{
	display: inline-block;
	float:left;
	width: 170px;
	height: 170px;
	margin: -12px 10px 3px -5px;
	border: 3px solid #FFF;
        background-color:#CCC;
	position: relative;
}

img.aspect {
    max-width:170px;
    max-height:170px;
    width:auto;
    height:auto;
    border: 0;
    position: absolute;
    top: 0; right: 0; bottom: 0; left: 0;
    margin: auto;
	float:left;

}

div.paragrafo{
	float:left;
	width:550px;
	height:90px;
}

h5.descrizione{
	font-size:11px;
}

h5.identificativo{
	font-size:14px;
	text-align:right;
}
Ho provato di tutti sul h5.identificativo... settaggio di padding, margin, vertical align, position absolute (come ho fatto per l'immagine)... ma niente... non va...

Qualcuno buono d'animo mi spiega come ottenere questo risultato..?

Ringrazio in anticipo chiunque risponderà o si prenderà la briga di leggere tutto sin qui...
Immagini allegate
File Type: jpg Nuova immagine bitmap.jpg (19.8 KB, 7 visite)
cenarius_88 è offline   Rispondi citando il messaggio o parte di esso
Old 15-11-2013, 14:08   #2
airon
Senior Member
 
Iscritto dal: Feb 2004
Città: milano
Messaggi: 2148
Basta mettere a paragrafo un:

position:relative;

Poi a identificativo usi:

position: absolute;
bottom: 0;
right: 0;

Così facendo posizioni in modo assoluto, rispetto a paragrafo, identificatore. Questo succede perché position: absolute prende come origine (coordinate 0,0 (sinistra,top)) il primo elemento padre con un position: xxxx settato (nel nostro caso quello messo a paragrafo).

Ultima modifica di airon : 15-11-2013 alle 14:12.
airon è offline   Rispondi citando il messaggio o parte di esso
Old 15-11-2013, 14:17   #3
cenarius_88
Member
 
Iscritto dal: Nov 2007
Città: Alcamo
Messaggi: 103
Quote:
Originariamente inviato da airon Guarda i messaggi
Basta mettere a paragrafo un:

position:relative;

Poi a identificativo usi:

position: absolute;
bottom: 0;
right: 0;

Così facendo posizioni in modo assoluto, rispetto a paragrafo, identificatore. Questo succede perché position: absolute prende come origine (coordinate 0,0 (sinistra,top)) il primo elemento padre con un position: xxxx settato (nel nostro caso quello messo a paragrafo).
Avevo già provato ma non va...
per ogni record va a mettere in una zona della pagina anche fuori dal container principale, l'elemento identificativo, e in più sovrapponendoli tra loro....
cenarius_88 è offline   Rispondi citando il messaggio o parte di esso
Old 15-11-2013, 14:21   #4
airon
Senior Member
 
Iscritto dal: Feb 2004
Città: milano
Messaggi: 2148
Vuol dire che non hai messo il position relative al padre giusto e quindi lui prende il body (di default).

Codice:
div.paragrafo{
	float:left;
	width:550px;
	height:90px;
position:realtive;
}



h5.identificativo{ 
position: absolute;
bottom: 0;
right: 0;
}
Ah ovviamente identificatore deve essere contenuto nel div paragrafo. Ah controlla anche che chiudi ad ogni ciclo il div elemento, non mi pare così al momento.
Un altro consiglio, non usare h5 per identificativo, usa un div

Ultima modifica di airon : 15-11-2013 alle 14:30.
airon è offline   Rispondi citando il messaggio o parte di esso
Old 15-11-2013, 14:43   #5
cenarius_88
Member
 
Iscritto dal: Nov 2007
Città: Alcamo
Messaggi: 103
Niente non va.... un po' è migliorato a seguito di alcune modifiche...

una prova a runtime (sorgente pagina)

Codice:
<div id="pagina"> 
<div class='elemento'>
<div class='immagine'><a href='images/numero_1.png'  target='_blank'><img class='aspect' src=' images/numero_1.png' /> </a> </div>
<div class='paragrafo'>Numero1</br> 
<h5 class='descrizione'>Descrizione</h5></br> 
<h5 class='identificativo'>1.66</h5></div>
</div>

<div class='elemento'>
<div class='immagine'><a href='images/numero_2.png'  target='_blank'><img class='aspect' src=' images/numero_2.png' /> </a> </div>
<div class='paragrafo'>Numero 2</br> 
<h5 class='descrizione'>Descrizione numero 2</h5></br>
<h5 class='identificativo'>5.44</h5></div>
</div>
</div>
</div>
Body
Codice:
body {
	background: #FFD1E4 url(../images/background.png) repeat; 
	font-family: Verdana, sans-serif; 
	color: #555; 
	font-size:18px; 
	text-align:justify; 
}
non c'è posizionamento...

CSS elemento -> modificato
Codice:
div.elemento {
	width:inherit;
	height:160px;
	background-color:#ffB1d5;
	/* Bordi arrotondati */
	border-radius: 0 20px 20px 0;
	-moz-border-radius: 0 20px 20px 0; /* per firefox */
	-webkit-border-radius: 0 20px 20px 0; /* per safari, chrome */
}

div.immagine{
	display: inline-block;
	float:left;
	width: 170px;
	height: 170px;
	margin: -12px 10px 3px -5px;
	border: 3px solid #FFF;
    background-color:#CCC;
	position: relative;
}

img.aspect {
    max-width:170px;
    max-height:170px;
    width:auto;
    height:auto;
    border: 0;
    position: absolute;
    top: 0; right: 0; bottom: 0; left: 0;
    margin: auto;
	float:left;

}

div.paragrafo{
	float:left;
	width:550px;
	height:90px;
	
	position:relative;
}

h5.descrizione{
	font-size:11px;
}

h5.identificativo{
	font-size:14px;
	text-align:right;
	
	position: absolute;
	bottom: 0;
	right: 0;
}
In allegato il risultato che ottengo adesso...

EDIT: si prima non chiudevo nulla e non erano in relazione padre figlio i contenitori... ho modificato lo script

Codice:
echo "<div class='elemento'>"; //apro div elemento
echo "<div class='immagine'>" . "<a href='" . $riga[4] ."'  target='_blank'>" . "<img class='aspect' src=' " . $riga[4] . "' /> </a> </div>"; // apro e chiudo div immagine
echo "<div class='paragrafo'>"; //apro div paragrafo
echo $riga[1] . "</br>"; //Titolo
echo " <h5 class='descrizione'>" .$riga[2]. "</h5></br>"; //Descrizione
echo " <h5 class='identificativo'>" . $riga[3] . "</h5>"; //Identificativo
echo "</div>"; // chiudo paragrafo
echo "</div>"; //chiudo elemento

echo "<br/>";
Immagini allegate
File Type: jpg Nuova immagine bitmap.jpg (21.6 KB, 4 visite)

Ultima modifica di cenarius_88 : 15-11-2013 alle 14:48.
cenarius_88 è offline   Rispondi citando il messaggio o parte di esso
Old 15-11-2013, 14:45   #6
airon
Senior Member
 
Iscritto dal: Feb 2004
Città: milano
Messaggi: 2148
Guarda l'altezza di paragrafo...non è quella che pensi tu...è 90px. Ecco perchè identificativo è così in alto e non al bordo di elemento. O cambi quello oppure metti il position: relative a elemento.
airon è offline   Rispondi citando il messaggio o parte di esso
Old 15-11-2013, 14:54   #7
cenarius_88
Member
 
Iscritto dal: Nov 2007
Città: Alcamo
Messaggi: 103
Quote:
Originariamente inviato da airon Guarda i messaggi
Guarda l'altezza di paragrafo...non è quella che pensi tu...è 90px. Ecco perchè identificativo è così in alto e non al bordo di elemento. O cambi quello oppure metti il position: relative a elemento.
Si l'altezza l'ho settata così perchè appunto vorrei che qualunque fosse l'altezza di paragrafo identificativo vada sotto....

A questo punto dovrei scorporare identificativo da paragrafo e settare relative elemento... ora provo vediamo che succede xD

EDIT: ok facendo in questo modo ho risolto metà quesito... ora sta di lato, in basso si ma ancora non attaccato al bordo... devo utilizzare un bottom con valore negativo?

EDIT 2: si mettendo valori negativi si avvicina al bordo u.u è una buona pratica?

Ultima modifica di cenarius_88 : 15-11-2013 alle 14:59.
cenarius_88 è offline   Rispondi citando il messaggio o parte di esso
Old 15-11-2013, 15:01   #8
airon
Senior Member
 
Iscritto dal: Feb 2004
Città: milano
Messaggi: 2148
Non è vicino al bordo perché gli elementi h (h1, h2, h3 ecc.) e quindi h5 hanno di default un margine.

O togli il margine all'elemento h5, o usi un div come ti avevo consigliato

Usare margini o posizionamenti negativi non è mai buona cosa


Usa l'inspector di chrome o firebug su firefox. Vedi tutte queste cose

Ultima modifica di airon : 15-11-2013 alle 15:10.
airon è offline   Rispondi citando il messaggio o parte di esso
Old 15-11-2013, 15:20   #9
cenarius_88
Member
 
Iscritto dal: Nov 2007
Città: Alcamo
Messaggi: 103
Quote:
Originariamente inviato da airon Guarda i messaggi
Non è vicino al bordo perché gli elementi h (h1, h2, h3 ecc.) e quindi h5 hanno di default un margine.

O togli il margine all'elemento h5, o usi un div come ti avevo consigliato

Usare margini o posizionamenti negativi non è mai buona cosa


Usa l'inspector di chrome o firebug su firefox. Vedi tutte queste cose
Non avevo capito assolutamente il problema del margine intrinseco dell'h*
Ho usato la distinzione in div come da te suggerito e i margini negativi non sono serviti (anzi ho dovuto aggiungere margine positivo per via dell'arrotondamento :P)

Molte grazie airon
cenarius_88 è offline   Rispondi citando il messaggio o parte di esso
Old 15-11-2013, 15:58   #10
airon
Senior Member
 
Iscritto dal: Feb 2004
Città: milano
Messaggi: 2148
Di niente
airon è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Recensione Samsung Galaxy Z Fold7: un grande salto generazionale Recensione Samsung Galaxy Z Fold7: un grande sal...
The Edge of Fate è Destiny 2.5. E questo è un problema The Edge of Fate è Destiny 2.5. E questo ...
Ryzen Threadripper 9980X e 9970X alla prova: AMD Zen 5 al massimo livello Ryzen Threadripper 9980X e 9970X alla prova: AMD...
Acer TravelMate P4 14: tanta sostanza per l'utente aziendale Acer TravelMate P4 14: tanta sostanza per l'uten...
Hisense M2 Pro: dove lo metti, sta. Mini proiettore laser 4K per il cinema ovunque Hisense M2 Pro: dove lo metti, sta. Mini proiett...
Windows 11 SE addio: Microsoft stabilisc...
Kali Linux più facile su macOS gr...
È la fine per le antenne 5G? Al l...
WhatsApp, una taglia da 1 milione di dol...
Sembrava spacciato, poi una bici elettri...
Apple Watch Series 1 diventa obsoleto: a...
ho. Mobile, upgrade a 250 GB senza sovra...
Reddit non avrà post a pagamento,...
Mercato auto in crisi in Italia: i priva...
Adesso puoi parlare con l'IA su WhatsApp...
AGCM bastona Shein: stangata da un milio...
Vendite di veicoli completamente elettri...
Tim Cook supera Steve Jobs: è il ...
Addio streaming illegale? Piracy Shield ...
Lunedì col botto: tablet e RTX 50...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 14:04.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
Served by www3v