Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Dreame Aqua10 Ultra Roller, la pulizia di casa con un rullo
Dreame Aqua10 Ultra Roller, la pulizia di casa con un rullo
Il più recente robot per la pulizia domestica di Dreame, modello Aqua10 Ultra Roller, abbina un potente motore di aspirazione della polvere a un sofisticato sistema di lavaggio con rullo integrato. Il tutto governato dalla logica di intelligenza artificiale, per i migliori risultati
Recensione Realme 15 Pro Game Of Thrones: un vero cimelio tech per pochi eletti
Recensione Realme 15 Pro Game Of Thrones: un vero cimelio tech per pochi eletti
Siamo volati fino a Belfast, capitale dell'Irlanda Del Nord, per scoprire il nuovo Realme 15 Pro 5G Game Of Thrones Limited Edition. Una partnership coi fiocchi, quella tra Realme e HBO, un esercizio di stile davvero ben riuscito. Ma vi raccontiamo tutto nel nostro articolo
GIGABYTE GAMING A16, Raptor Lake e RTX 5060 Laptop insieme per giocare al giusto prezzo
GIGABYTE GAMING A16, Raptor Lake e RTX 5060 Laptop insieme per giocare al giusto prezzo
Il Gigabyte Gaming A16 offre un buon equilibrio tra prestazioni e prezzo: con Core i7-13620H e RTX 5060 Laptop garantisce gaming fluido in Full HD/1440p e supporto DLSS 4. Display 165 Hz reattivo, buona autonomia e raffreddamento efficace; peccano però le USB e la qualità cromatica del pannello. Prezzo: circa 1200€.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 14-03-2008, 11:26   #1
keyg
Junior Member
 
Iscritto dal: Mar 2008
Messaggi: 8
[javascript] modificare colore

vorrei modificare il colore del testo all'interno della pagina...

i passaggi sono:
-trova gli elementi della pagina(codice non riportato..troppo lungo)
-controlla se ci sono elementi
_per ogni elemento mi toglie rimuove quello che c'è all'interno e modifica il colore del testo...

ma c'è qualcosa che non va!..

questo è il codice

.........


//controlla se ci sono elementi nella pagina
if (Elements.length > 0)
{



var element = null;
var styleElem = null;
var textNode = null;
var styleText= "#FF00FF" ;



for (Counter=0; Counter<Elements.length; Counter++)
{





//rimuove elemento

while(element = Elements[Counter].getElementById(id)) {
element.parentNode.removeChild(element);
}




styleElem = Elements[Counter].createElement("style");
styleElem.setAttribute("id", id);
styleElem.setAttribute("type", "text/css");

textNode = Elements[Counter].createTextNode( styleText );

styleElem.appendChild(textNode);


Elements[Counter].documentElement.childNodes[0].appendChild(styleElem);

}
}


....


ho provato in questo modo, ma nulla da fare...
riuscireste a darmi qualche dritta?..
grazie!
keyg è offline   Rispondi citando il messaggio o parte di esso
Old 14-03-2008, 12:01   #2
andbin
Senior Member
 
L'Avatar di andbin
 
Iscritto dal: Nov 2005
Città: TO
Messaggi: 5206
Se una variabile elem rappresenta un elemento, allora ad esempio:

elem.style.color = "#FF00FF";

imposta il colore dell'elemento.
__________________
Andrea, SCJP 5 (91%) - SCWCD 5 (94%)
andbin è offline   Rispondi citando il messaggio o parte di esso
Old 16-03-2008, 11:22   #3
keyg
Junior Member
 
Iscritto dal: Mar 2008
Messaggi: 8
...il problema è che alla lista element devo andare a togliere il nodo trovato...e aggiungere al posto di quel nodo un'altro nodo...


ho provato in questo modo...


if (Elements.length > 0)
{

var colTesto = null;
var styleElem = null;
var textNode = null;
var styleText = null;
var color = "#FF00FF";

for (Counter=0; Counter<Elements.length; Counter++)
{


//trova elementi color
styleElem = Elements[Counter].getElementsByTagName('color');

//rimuove elemento dal nodo
styleElem.removeChild(styleElem);

//crea un'altro elemento
styleElem = Elements[Counter].createElement("style");
styleElem.setAttribute("id", id);
styleElem.setAttribute("type", "text/css");

//aggiunge il colore
styleText = "* { color: " + color + " !important; }";

//crea il text nodo
textNode = Elements[Counter].createTextNode( styleText );

//lo aggiunge all'elemento
styleElem.appendChild(textNode);

//modifica la struttura
Elements[Counter].documentElement.appendChild(styleElem);




}



...anche così non va bene!...
qualcuno sa dove posso sbatter la testa?...

grazie per l'aiuto!..
keyg è offline   Rispondi citando il messaggio o parte di esso
Old 16-03-2008, 13:05   #4
vladix
Member
 
L'Avatar di vladix
 
Iscritto dal: Jan 2008
Città: roma
Messaggi: 296
puoi semlicemente fare con
Codice:
   node.replaceChild(novoDaRimuovere , nuovoNodo);
ma non capisco ... tu stai cercando di creare na classe di stile con il pezzo di codice che hai postato ? xche se cosi fose , stai ben lontano dal realizzarla

stai sbagliando gia dalla prima riga
Codice:
Elements[Counter].getElementsByTagName('color')
ritorna un array quindi gli devi dire l'elemento su quale elemento deve operare ( anche se contiene un solo elemento , ritorna sempre un array quindi te lo devi prendere cosi document.getElementsByTagName('color')[0];
e poi qui
Codice:
  styleElem.removeChild(styleElem);
stai cercando di togliere il nodo styleElem dal nodo ... styleElem , e suppongo che tu abbia un nodo con il tag "<color>" nella tua pagina se no
".getElementsByTagName('color')" non ti trova niente , e se c'e l'hai sei un po fuori strada ... invecce di scorerti tutti gli elementi della pagina scorri solo gli elementi trovati ,

Codice:
  for(i = 0; i < document.getElementsByTagName('color').length; i++){
    var xd =  document.getElementsByTagName('color')[i];
    xd.parentNode.replace(xd , nuovoNodo);
   }
cmq ti consiglio di legerti una guida dom x fa sta cosa
PS: vorrei sapere xche gli dai un id al elemento style ... a cosa serve
vladix è offline   Rispondi citando il messaggio o parte di esso
Old 16-03-2008, 15:23   #5
keyg
Junior Member
 
Iscritto dal: Mar 2008
Messaggi: 8
...prima di tutto grazie per il consiglio...io stavo seguendo un tutorial in inglese e non ci stavo capendo molto!...

quello che voglio fare...è prendere il colore del testo di alcune elementi all'interno della pagina e modificarglielo...

io ho un array "Elements" con all'interno gli elementi della pagina

quindi:

//controllo che ci siano deli elementi all'interno della pagina

if (Elements.length > 0)
{

//scorro tutti gli elementi

for (Counter=0; Counter<Elements.length; Counter++)
{

in teoria adesso vorrei modificare il colore del testo deli elementi trovati, quindi...quello che mi era venuto in mente era questo

rimuovo l'elemento trovato..e ne rimetto un altro uguale modificandogli il colore

quindi da quello che mi hai spiegato(se non ho capito male!)..dovrei aggiungere..

for(i = 0; i < Elements[Counter].getElementsByTagName('color').length; i++)

{
var xd = Elements[Counter].getElementsByTagName('color')[i];
xd.parentNode.replaceChild(xd , nuovoNodo);
nuovoNodo.style.color="#FF00FF";


}


}
}



grazie per l'aiuto!
keyg è offline   Rispondi citando il messaggio o parte di esso
Old 16-03-2008, 15:34   #6
vladix
Member
 
L'Avatar di vladix
 
Iscritto dal: Jan 2008
Città: roma
Messaggi: 296
ma scusa , se a te serve solo cambiare il colore , basta che risetti il colore ( come ha detto gia andbin )

Codice:
for(i = 0; i < Elements[Counter].getElementsByTagName('color').length; i++){
 var xd = Elements[Counter].getElementsByTagName('color')[i];
      xd.style.color="#FF00FF";
}
vladix è offline   Rispondi citando il messaggio o parte di esso
Old 16-03-2008, 15:41   #7
keyg
Junior Member
 
Iscritto dal: Mar 2008
Messaggi: 8
così..ho già provato...

ma mi da questo errore...

"Errore: uncaught exception: Permesso negato al metodo di chiamata Location.toString"..

è quindi non so che pesci prendere!..
keyg è offline   Rispondi citando il messaggio o parte di esso
Old 16-03-2008, 16:03   #8
vladix
Member
 
L'Avatar di vladix
 
Iscritto dal: Jan 2008
Città: roma
Messaggi: 296
strano , metti un po di alert qua e la , vedi se Element e vuoto , e sopratutto vedi che ti ritorna
ma ora che ci penso ... tu hai elementi in pagina col tag <color> ?

qui un pezzo di codice ( che funziona benissimo ) di esempio ...
Codice:
<html>
<head>
</head>
<script>
  function change(){
     var elm = document.getElementsByTagName('span');
         elm[0].style.color = "#333399";
  }
</script>
<body>
  <span style="color:#CC6633">Testo Colorato
  </span>
  <input type="button" value=":=)" onclick="change();"
</body>
</html>
vladix è offline   Rispondi citando il messaggio o parte di esso
Old 17-03-2008, 08:50   #9
keyg
Junior Member
 
Iscritto dal: Mar 2008
Messaggi: 8
no no..element non è vuoto..
se io metto queste due righe nel ciclo

colText = Elements[Counter].forecolour.hexcolour;

alert("trovato " + colText);

mi trova tutti i colori del testo esadecimali che ci sono nella pagina..

il problema è che se provo a modificare la pagina in questo modo

colText.style.color = "#FF00FF";

non mi modifica nulla!..
non capisco se devo togliere il nodo e crearne uno nuovo...
keyg è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Dreame Aqua10 Ultra Roller, la pulizia di casa con un rullo Dreame Aqua10 Ultra Roller, la pulizia di casa c...
Recensione Realme 15 Pro Game Of Thrones: un vero cimelio tech per pochi eletti Recensione Realme 15 Pro Game Of Thrones: un ver...
GIGABYTE GAMING A16, Raptor Lake e RTX 5060 Laptop insieme per giocare al giusto prezzo GIGABYTE GAMING A16, Raptor Lake e RTX 5060 Lapt...
iPhone 17 Pro: più di uno smartphone. È uno studio di produzione in formato tascabile iPhone 17 Pro: più di uno smartphone. &Eg...
Intel Panther Lake: i processori per i notebook del 2026 Intel Panther Lake: i processori per i notebook ...
Panasonic Lumix S9: disponibile in quatt...
Nikon presenta due obiettivi: NIKKOR Z D...
Horizon vs Light of Motiram, si entra ne...
Atari rilancia Intellivision Sprint e fa...
Leapmotor lancia in Italia il SUV elettr...
QNAP punta sempre più in alto con...
Scandalo ibride plug-in: consumano come ...
L'intelligenza artificiale fa sempre pi&...
Oracle dal punto di vista dell’Europa: l...
James Dyson Award 2025: dall'accessibili...
Xiaomi: gli smartphone con display poste...
Final Fantasy 7 Remake Part 3 offrir&agr...
Chery presenta Omoda 4, da benzina a ele...
TSMC alza i prezzi: Qualcomm e MediaTek ...
Una Offline Room per aiutare gli student...
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: 05:14.


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