- Home
- Categorie
- Coding e Sistemistica
- PHP
- sito dinamico
-
scusa, mi fai uno screenshot del mouse sul bottone che ha appena cliccato ed è comparso il layer?
Nel tuo caso non usi getElementById, o meglio... vuoi svincolarti dall'evento del mouse?
onclick="document.getElementById('id_del_layer').style.cssText = 'visibility:visible;top:XXpx;left:XXpx'"
A quell'id applichi una classe staticamente che definisce "position:absolute;visibility:hidden" e le cose fisse
In questo modo al click del mouse il layer diventa visibile e si "piazza" dove dici tu e per ogni bottone puoi individuare dove lo vuoi... (ci sono modi più belli esteticamente a livello di codice, ma non conosco bene la tua pagina)
keiske
keiske
-
allora i cerchi rossi indicano i vari campi che richiamano il calendario e nel caso dei bottoni in alto il calendario compare in una posizione accettabile mentre nel caso dei bottoni in basso il calendario non scende di molto e cmq rimane visualizzato sempre troppo in alto e mi tocca scrollare la pagina.
-
ma il calendario che appare è sempre lui? O cambia a seconda del bottone che premi? Lo facevi un po' più piccolo lo screenshot e mi serviva un microscopio elettronico
keiske
-
scusami ma non sono stato io a farlo piccolo ma le restrizioni degli allegati del forum ma cmq si è sempre lo stesso calendario
-
ho messo questo codice
[PHP]alert(xPos+","+yPos);[/PHP]
nella funzione che richiama il calendario dopo le famosissime variabili xPos e yPos ed ho cliccato su tutti i bottoni partendo dall'alto in giù ed ho avuto i seguenti risultati:
685,199
685,230
685,93
685,151
685,208
questo mi dimostra che essendo i primi due bottoni in una tabella ed i restanti bottoni in un'altra tabella il calendario elabora le posizioni relative e non quelle assolute della pagina.
Mo' che faccio?
-
Allora perchè scusa non usi il sistema che ho detto prima, magari perfezionandolo?
imposta il div del calendario tutto per benino... poi dagli "position:relative;left:10px;top:10px;visibility:hidden"
Poi assegna ai bottoni sull'evento onclick di dare visibilità al layer che teoricamente dovrebbe apparire 10 pixel a sinistra e 10 sopra rispetto all'elemento bottone (il div è "relativo")... almeno io ho gli aiuti in linea e li faccio così... appaiono un po' spostati con "relazione" al link... però io di fianco ad ogni "link" di aiuto metto il codice che richiama il layer (ma lo stile è nel css per tutti i layer)
keiske
edit: controlla se il "div" è impostato relativo o assoluto, oppure prova a usare il float
-
forse ho trovato questo codice che mi ha chiarito un po' le idee
[PHP]
<script>
function test()
{
if (document.layers) getMouseLoc; //NS
else if (document.all) getMouseLoc(); //IE
alert(mouseLocation.x+","+mouseLocation.y);
}function Point(x,y) { this.x = x; this.y = y; }
mouseLocation = new Point(-500,-500);
function getMouseLoc(e)
{
if(!document.all) //NS
{
mouseLocation.x = e.pageX;
mouseLocation.y = e.pageY;
}
else //IE
{
mouseLocation.x = event.x + document.body.scrollLeft;
mouseLocation.y = event.y + document.body.scrollTop;
}
return true;
}
if(document.layers){ document.captureEvents(Event.MOUSEMOVE); document.onMouseMove = getMouseLoc; }
</script><a href="#" onClick="test()">ooooooooooooooooooooooooo</a>
[/PHP]
infatti adattandolo un po' cioè scrivendo
[PHP]
xPos = event.x + document.body.scrollLeft;
yPos = event.y + document.body.scrollTop;
[/PHP]
il tutto quasi torna dico quasi perchè viene spostato un pochino più in basso il calendario per i bottoni in alto invece è perfetto per quelli in basso
-
ti ringrazio per l'attenzione.
Alla fine ho risolto così un po' brutale ma funzionante
[PHP]
if(val=='datacompleta1' || val=='datacompleta2'){
xPos = event.x;
yPos = event.y;
}else{
xPos = event.x + document.body.scrollLeft;
yPos = event.y + document.body.scrollTop;
}
[/PHP]
cioè per i bottoni di sopra funziona come sempre ha funzionato per il resto segui le coordinate della pagina.
-
Sì ma allora le funzioni sono condizionate da dove hai messo i bottoni, nel senso che sono dentro blocchi e oggetti inline... magari potresti vedere se la struttura è ottimizzata o se c'è qualche elemento di troppo...
keiske
edit: perfetto
-
avendo un database con una tabella in particolare sulla quale più utenti potrebbero inserire dei dati come posso creare un codice php che mi permetta di non avere collisioni di richieste?
Cioè:come chiave primaria della tebella in questione ho le colonne:
- ID_INS = intero crescente indicante l'inserimento
- DATA_INS = data dell'inserimento
- STATO = indicante la tipologia dello stato (es. INS inserimento,ANN annullato,MOD modificato)
dove il codice creato da me legge il massimo dell'ID_INS e lo incrementa di una unità e così inserisce una nuova riga nella tabella.
Il mio dubbio proviene dal fatto che se un utente fa una richiesta di inserimento nella tabella e quindi riceve il massimo dell'ID_INS e quasi contemporaneamente un altro utente ne fa richiesta e li viene associato lo stesso ID_INS perchè il primo non ha ancora registrato allora all'ultimo li verrà negata la richiesta di inserimento perchè esiste già un record con quell'ID_INS.
Chi mi sa dare un consiglio?