Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto
Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto
Xiaomi ha portato sul mercato internazionale la nuova serie Redmi Note, che rappresenta spesso una delle migliori scelte per chi non vuole spendere molto. Il modello 15 Pro+ punta tutto su una batteria capiente e su un ampio display luminoso, sacrificando qualcosa in termini di potenza bruta e velocità di ricarica
HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione
HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione
HONOR ha finalmente lanciato il suo nuovo flagship: Magic 8 Pro. Lo abbiamo provato a fondo in queste settimane e ve lo raccontiamo nella nostra recensione completa. HONOR rimane fedele alle linee della versione precedente, aggiungendo però un nuovo tasto dedicato all'AI. Ma è al suo interno che c'è la vera rivoluzione grazie al nuovo Snapdragon 8 Elite Gen 5 e alla nuova MagicOS 10
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata
Le webcam Insta360 Link 2 Pro e Link 2C Pro sono una proposta di fascia alta per chi cerca qualità 4K e tracciamento automatico del soggetto senza ricorrere a configurazioni complesse. Entrambi i modelli condividono sensore, ottiche e funzionalità audio avanzate, differenziandosi per il sistema di tracciamento: gimbal a due assi sul modello Link 2 Pro, soluzione digitale sul 2C Pro
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 08-04-2013, 20:38   #1
kwb
Senior Member
 
L'Avatar di kwb
 
Iscritto dal: Jul 2003
Città: Alessandria
Messaggi: 10167
[jQuery]Chrome e posizionamento elemento

Ciao a tutti!
Ho sviluppato uno script in JS-jQuery che posiziona al centro ( orizzontalmente ) un div.
Ho dovuto fare questa cosa perchè ho un'immagine e questo div appunto, dentro il "wrapper" diciamo, ciò che li racchiude. La struttura ( semplificata ) è la seguente:
Codice:
<div class="wrapper">
<img src"blabla.jpg" style="float: left;" id="miaImg"/>
<div id="altro"></div>
</div>
Ora, ho bisogno di posizionare al centro del div wrapper il mio div altro. Chiaramente per farlo devo prima togliere la larghezza dell'immagine, per capire quanto spazio mi avanza per posizionare l'elemento.
Detto ciò, ho scritto questo in JS:
Codice:
$(document).ready(
		function centerHeaderText(){
			var widthParent = $(".wrapper").width();
			var widthLogo = $("#miaImg").width(); 
			var widthElement = $("#altro").width();
			
			widthParent -= widthLogo;
			$("#altro").css({ "position": "relative", "left": (widthParent-widthElement)/2});
		}
	)
Questo script funziona perfettamente su tutti i browser, eccetto Chrome.
Ho letto che il problema può essere dovuto al fatto che siccome lo script viene eseguito quando il DOM è carico ( ma le immagini non ancora ), allora Chrome fa pasticci...

Prendendo spunto da qui: http://stackoverflow.com/questions/2...idth-in-chrome ho provato anche a cambiare l'evento con $(window).load ma anzi, peggiora la situazione, calcolandomi un valore completamente errato per qualunque browser.

Chiudo dicendo che per altre ragioni, non ho la possibilità di specificare a priori la dimensione dell'immagine ne nel tag html ne nel css ( e non voglio specificarle!! )

Qual è il problema? Come si risolve?
__________________
Dell XPS 13 (9350) :: i5-2500K - HD6870 - AsRock Z68 Pro3 - Corsair Vengeance 8GB (4x2) DDR3 :: Samsung Galaxy S4 GT-i9505
kwb è offline   Rispondi citando il messaggio o parte di esso
Old 09-04-2013, 10:57   #2
wingman87
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 2785
Se il problema è il caricamento di un'immagine puoi fare una cosa del genere:
Codice:
var imgSrc = $('imgSelector').attr('src');
var image = new Image();
image.onload = function() {
	//qui la dimensione dell'immagine è disponibile
};
image.src = imgSrc;
Dove "imgSelector" è il selettore per l'immagine che ti interessa.
Questo (se non ho fatto errori) dovrebbe funzionare, non ho usato l'handler load di jQuery perché nella documentazione c'è scritto che con le immagini non è sempre affidabile:
http://api.jquery.com/load-event/
wingman87 è offline   Rispondi citando il messaggio o parte di esso
Old 09-04-2013, 12:48   #3
kwb
Senior Member
 
L'Avatar di kwb
 
Iscritto dal: Jul 2003
Città: Alessandria
Messaggi: 10167
Ho ricontrollato bene le varie dimensioni, facendo stampare a entrambi i browser ( FF e Chrome ) le larghezze che calcolavano per i 3 elementi: l'immagine, il genitore e l'elemento da posizionare.
Fatto stà che le dimensioni dei div risultavano diverse ( usando document.ready ho verificato che Chrome ritorna 0 di larghezza dell'immagine, con window.load invece è corretto ): mi sono poi accorto di una differenza sostanziale, ovvero che Firefox visualizza la barra di scorrimento verticale della pagina sempre, e quindi va a mangiare quei 6px ( 5.5px per l'esattezza ) che non mi tornavano su Chrome, dove invece la barra di scorrimento è sovrapposta e invisibile quando non si scrolla.

Il problema si è quindi risolto sostituendo window.load a document.ready

Un'ultima cosa, come faccio a rieseguire una funzione ( ad esempio questa per il posizionamento del div ) se ad esempio viene ridimensionata la finestra del browser? Oppure se si cambia la visualizzazione su un tablet da portrait a landscape?

Kwb
__________________
Dell XPS 13 (9350) :: i5-2500K - HD6870 - AsRock Z68 Pro3 - Corsair Vengeance 8GB (4x2) DDR3 :: Samsung Galaxy S4 GT-i9505
kwb è offline   Rispondi citando il messaggio o parte di esso
Old 09-04-2013, 14:04   #4
wingman87
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 2785
Per il ridimensionamento esiste l'evento resize di jQuery:
http://api.jquery.com/resize/

Per il cambio di orientamento sono meno ferrato ma dovrebbe esistere l'evento orientationchange, prova a vedere questo link:
http://davidwalsh.name/orientation-change
wingman87 è offline   Rispondi citando il messaggio o parte di esso
Old 09-04-2013, 22:14   #5
kwb
Senior Member
 
L'Avatar di kwb
 
Iscritto dal: Jul 2003
Città: Alessandria
Messaggi: 10167
Quote:
Originariamente inviato da wingman87 Guarda i messaggi
Per il ridimensionamento esiste l'evento resize di jQuery:
http://api.jquery.com/resize/
Perfetto, funziona!
__________________
Dell XPS 13 (9350) :: i5-2500K - HD6870 - AsRock Z68 Pro3 - Corsair Vengeance 8GB (4x2) DDR3 :: Samsung Galaxy S4 GT-i9505
kwb è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto Redmi Note 15 Pro+ 5G: autonomia monstre e displ...
HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione HONOR Magic 8 Pro: ecco il primo TOP del 2026! L...
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata Insta360 Link 2 Pro e 2C Pro: le webcam 4K che t...
Motorola edge 70: lo smartphone ultrasottile che non rinuncia a batteria e concretezza Motorola edge 70: lo smartphone ultrasottile che...
Display, mini PC, periferiche e networking: le novità ASUS al CES 2026 Display, mini PC, periferiche e networking: le n...
La nave elettrica più grande mai ...
Spusu lancia il Wi-Fi Calling: come funz...
Questo robot impara a muovere le labbra ...
iPhone 17 annienta la concorrenza in Cin...
La nuova Xiaomi SU7 batte un record: 4.2...
È possibile copiare i qubit: dei ...
BYD alza ulteriormente l'asticella: batt...
Il nuovo razzo spaziale riutilizzabile c...
L'ex leader di Assassin's Creed porta Ub...
Il razzo spaziale NASA SLS e la capsula ...
Samsung Galaxy S26 Ultra: quattro colora...
AWS investe 1,2 miliardi in Italia. Coin...
La navicella cinese Shenzhou-20 con il f...
I piani Business ed Education di Google ...
Ceres-2 e Lunga Marcia 3B: la Cina falli...
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: 20:49.


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