|
|||||||
|
|
|
![]() |
|
|
Strumenti |
|
|
#1 |
|
Senior Member
Iscritto dal: Jul 2002
Città: Hampstead, London
Messaggi: 2449
|
[DHTML] Coordinate DIV?
Ho uno script che crea un menu a tendina, ma questo script chiede di impostare le coordinate giuste x e y, ma questo mi rovina tutto se ridimensiono la pagina, dato che è in formato "larga colonna centrale"
mi servirebbe quindi trovare le cordinate del DIV dove dovrebbe stare, in modo da crearlo lì dentro ad ogni esecuzione o ancora meglio trovare il modo di eliminare questa prepotenza della posizione statica
__________________
stabilmente instabile |
|
|
|
|
|
#2 |
|
Senior Member
Iscritto dal: Sep 2001
Città: Pesaro
Messaggi: 921
|
io per avere le coordinate di un oggetto uso questo:
Codice:
function getAbsolutePosition(el)
{
var r = {x: el.offsetLeft, y: el.offsetTop};
if (el.offsetParent) {
var tmp = getAbsolutePosition(el.offsetParent);
r.x += tmp.x;
r.y += tmp.y;
}
return r;
}
non funziona sempre e su tutte le pagine, con pagine un po' strane so che può dare dei problemi. A me fin'ora è andata bene.
__________________
"Vedi, molte delle verità che affermiamo, dipendono dal nostro punto di vista" "Se coloro che vi guidano vi dicono: «Ecco! Il Regno è nel cielo», allora gli uccelli del cielo vi saranno prima di voi. Se essi vi dicono: «Il Regno è nel mare», allora i pesci vi saranno prima di voi. Ma il Regno è dentro di voi ed è fuori di voi" |
|
|
|
|
|
#3 |
|
Senior Member
Iscritto dal: Jul 2002
Città: Hampstead, London
Messaggi: 2449
|
ho parzialmente trovato la soluzione
con queste due righette dovrei trovare le coordinate dell'angolo in alto a sinistra del DIV "navigation" var y= document.all("navigation").currentStyle.top var x= document.all("navigation").currentStyle.left queste altre due righe poi posizionano il menù correttamente nella pagina //Variables to set: slideMenu.menuy= 120 //The top placement of the menu. slideMenu.menux= x //The left placement of the menu ma questo funziona solo con IE...con firefox mi sfascia la struttura della pagina se provo a mettere un: document.write(y) document.write(x) in IE mi ritrovo scritto "autoauto", eppure funziona...che vuol dire?
__________________
stabilmente instabile |
|
|
|
|
|
#4 |
|
Senior Member
Iscritto dal: Jul 2002
Città: Hampstead, London
Messaggi: 2449
|
funziona!
ti voglio bene! però così tipo se ridimensiono dopo devo fare un aggiorna per rimettere il menu al suo posto qual'è il modo migliore per aggirare questo fastidio?
__________________
stabilmente instabile |
|
|
|
|
|
#5 | |
|
Senior Member
Iscritto dal: Sep 2001
Città: Pesaro
Messaggi: 921
|
Quote:
In realtà io l'ho copiata altrove. Guarda ti faccio un altro regalo (se non lo conoscevi già) http://www.google.com/codesearch cerca in tutto il codice open source, qualsiasi linguaggio (specificabile, per trovare questa funzione ho usato "lang:javascript") se devi sovrapporre il menu al resto della pagina (come penso) l'unico modo è appunto avere un div con posizione assoluta (come fai già) e dunque devi riposizionare tutto quando la pagina viene ridimensionata.
__________________
"Vedi, molte delle verità che affermiamo, dipendono dal nostro punto di vista" "Se coloro che vi guidano vi dicono: «Ecco! Il Regno è nel cielo», allora gli uccelli del cielo vi saranno prima di voi. Se essi vi dicono: «Il Regno è nel mare», allora i pesci vi saranno prima di voi. Ma il Regno è dentro di voi ed è fuori di voi" |
|
|
|
|
|
|
#6 |
|
Senior Member
Iscritto dal: Jul 2002
Città: Hampstead, London
Messaggi: 2449
|
fenomenale questo google codesearch!
esatto ho usato proprio la funzione che hai postato sopra adesso sto cercando qualcosa del tipo onResize() così da spostare il menu ogni volta che c'è il ridimensionamento EDIT: <body onresize="location.reload()"> funziona, ma solo su Internet Explorer! dannazione
__________________
stabilmente instabile Ultima modifica di spk : 12-12-2006 alle 00:53. |
|
|
|
|
|
#7 | |
|
Senior Member
Iscritto dal: Sep 2001
Città: Pesaro
Messaggi: 921
|
Quote:
e comunque onresize esiste ed è un evento dell'oggetto window, come puoi vedere qui: http://www.devguru.com/Technologies/..._onresize.html P.s.: altra possibile guida al javascript http://developer.mozilla.org/en/docs...ript_1.5_Guide
__________________
"Vedi, molte delle verità che affermiamo, dipendono dal nostro punto di vista" "Se coloro che vi guidano vi dicono: «Ecco! Il Regno è nel cielo», allora gli uccelli del cielo vi saranno prima di voi. Se essi vi dicono: «Il Regno è nel mare», allora i pesci vi saranno prima di voi. Ma il Regno è dentro di voi ed è fuori di voi" |
|
|
|
|
|
|
#8 |
|
Senior Member
Iscritto dal: Jul 2002
Città: Hampstead, London
Messaggi: 2449
|
devo ancora studiare come funzionano gli event handler in javascript, ma per oggi è abbastanza
sinceramente è la prima volta che costruisco un sito interamente in CSS + DHTML ... ma è per un'associazione di volontariato quindi ci tengo a fare le cose per bene nel frattempo ti ringrazio per le guide postate, saranno i primi riferimenti!
__________________
stabilmente instabile |
|
|
|
|
|
#9 |
|
Senior Member
Iscritto dal: Jul 2002
Città: Hampstead, London
Messaggi: 2449
|
ho individuato la funzione che mi serve
window.onresize = function onresize() { alert('ciao') } così facendo ho il messaggino appena ridimensiono, ma non riesco a spostare il menù poiche l'init dello stesso avviene alla creazione della pagina, e non mi è possibile spostarlo senza un refresh se riprovo a dare l'init() mi da pagina bianca come in loop sto cercando di fare un refresh al redimensionamento tramite il metodo reload() come descritto qui http://www.devguru.com/Technologies/...ef/reload.html ma non mi funziona ne in IE nè in firefox
__________________
stabilmente instabile |
|
|
|
|
|
#10 | |
|
Senior Member
Iscritto dal: Sep 2001
Città: Pesaro
Messaggi: 921
|
Quote:
nell'onresize devi dargli solo le istruzioni per riposizionare il menu, non devi reinizializzare tutto. Il reload non è affatto una soluzione in quanto ricarica dal server TUTTA la pagina, come se tu premessi il bottone di refresh. Inoltre se per caso al caricamento della pagina tu cambi le dimensioni della finestra per qualche motivo, fai scattare di nuovo l'onresize che fa il reload che ricarica la pagina e così via a ciclo continuo. Usare il reload è un problema in più, non la soluzione.
__________________
"Vedi, molte delle verità che affermiamo, dipendono dal nostro punto di vista" "Se coloro che vi guidano vi dicono: «Ecco! Il Regno è nel cielo», allora gli uccelli del cielo vi saranno prima di voi. Se essi vi dicono: «Il Regno è nel mare», allora i pesci vi saranno prima di voi. Ma il Regno è dentro di voi ed è fuori di voi" |
|
|
|
|
|
|
#11 | |
|
Senior Member
Iscritto dal: Jul 2002
Città: Hampstead, London
Messaggi: 2449
|
Quote:
capisco allora lavoro sull'init, ma ora ti spiego come funziona: dopo aver importato il sidemenu.js (non altro che un cumulo di funzioni) si apre uno script all'interno della pagina dove si creano due variabili slideMenu.menuy= 120 //The top placement of the menu. slideMenu.menux= x //The left placement of the menu dove al momento x è var x =getAbsolutePosition(navigation).x (grazie ancora "navigation" è il nome del DIV (il frameset è emulato coi css) a fine script si da il slideMenu.init() ed il menù viene creato all'interno della pagina se provo a ricrearlo nel resize()...mi da quella pagina bianca che ti dicevo insomma qua crea l'oggetto slideMenu = new createSlideMenu("slideMenu") adesso sto pensando di "distruggere l'oggetto" per poi ricrearlo, tutto all'interno della funzione del resize
__________________
stabilmente instabile |
|
|
|
|
|
|
#12 | |
|
Senior Member
Iscritto dal: Sep 2001
Città: Pesaro
Messaggi: 921
|
Quote:
Se lo script che stai utilizzando per caso è questo: http://www.google.com/codesearch?hl=...lidemenu.js#a0 me lo sono guardato un attimo e sembra che abbia un metodo suo proprio per muoverlo. Dopo aver assegnato menux e menuy a slideMenu, invece che rifare slideMenu.init() fai slideMenu.cont.moveIt(slideMenu.menux,slideMenu.menuy) e vedi se funzia. Comunque appunto devi solo muovere quel che c'è già non rifarlo da capo.
__________________
"Vedi, molte delle verità che affermiamo, dipendono dal nostro punto di vista" "Se coloro che vi guidano vi dicono: «Ecco! Il Regno è nel cielo», allora gli uccelli del cielo vi saranno prima di voi. Se essi vi dicono: «Il Regno è nel mare», allora i pesci vi saranno prima di voi. Ma il Regno è dentro di voi ed è fuori di voi" |
|
|
|
|
|
|
#13 |
|
Senior Member
Iscritto dal: Jul 2002
Città: Hampstead, London
Messaggi: 2449
|
non funziona
ho provato in ogni modo ma pare proprio che quella funzione possa essere richiamata solo dal metodo init() e non dall'esterno ma come funziona il public e provate in javascript?
__________________
stabilmente instabile |
|
|
|
|
|
#14 | ||
|
Senior Member
Iscritto dal: Sep 2001
Città: Pesaro
Messaggi: 921
|
Quote:
Quote:
__________________
"Vedi, molte delle verità che affermiamo, dipendono dal nostro punto di vista" "Se coloro che vi guidano vi dicono: «Ecco! Il Regno è nel cielo», allora gli uccelli del cielo vi saranno prima di voi. Se essi vi dicono: «Il Regno è nel mare», allora i pesci vi saranno prima di voi. Ma il Regno è dentro di voi ed è fuori di voi" |
||
|
|
|
|
|
#15 | |
|
Senior Member
Iscritto dal: Jul 2002
Città: Hampstead, London
Messaggi: 2449
|
Quote:
__________________
stabilmente instabile |
|
|
|
|
|
| Strumenti | |
|
|
Tutti gli orari sono GMT +1. Ora sono le: 16:29.



















