Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Dreame X60 Pro Ultra Complete: i bracci si estendono sempre di più
Dreame X60 Pro Ultra Complete: i bracci si estendono sempre di più
Dreame X60 Pro Ultra Complete implementa due bracci estensibili, per spazzola e moccio, che si spingono ben oltre quanto visto sino ad oggi permettendo una pulizia di casa ancor più capillare e precisa
TCL 65C8L, la recensione del SQD-Mini LED da 4400 nit misurati
TCL 65C8L, la recensione del SQD-Mini LED da 4400 nit misurati
La tecnologia SQD-Mini LED di TCL arriva sul taglio da 65 pollici con la serie C8L: 2040 zone, pannello WHVA 2.0 e un picco che alle rilevazioni delle sonde tocca i 4400 nit nel profilo Filmmaker e un HDR quasi perfetto
MSI Maestro 500 Wireless: ANC e 90 ore di autonomia a 70 euro
MSI Maestro 500 Wireless: ANC e 90 ore di autonomia a 70 euro
Wireless 2.4 GHz, Bluetooth 5.4, cancellazione attiva del rumore, design pieghevole e un'autonomia che mette in imbarazzo prodotti che costano il doppio. Le Maestro 500 non eccellono in nulla, ma offrono tutto. E a questo prezzo è difficile chiedere di più
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 02-11-2010, 17:25   #1
Player1
Senior Member
 
Iscritto dal: Feb 2002
Messaggi: 1370
[javascript] Aiuto per la creazione della mia prima pagina web con javascript.

Ciao!
Sto cercando di scrivere la mia prima pagina web che fa uso di javascript, ho letto diverse guide tuttavia al momento di mettere in pratica gli insegnamenti mi sono bloccato subito.
Avrei bisogno di una mano, iniziamo dal primo problema, l'uso delle variabili, questo è il codice (o meglio parte del codice) che ho scritto:
Codice:
<%@page contentType="text/html" pageEncoding="UTF-8"%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
   "http://www.w3.org/TR/html4/loose.dtd">

<html>
    <head>
        <meta http-equiv="Content-Type" content="text/html;charset=UTF-8">
                 ...
		<script type="javascript" >
			var state = new String("ciao");
		</script>
    </head>
    <body>
                ...
	<div id="content">
		<font color="red">
                        <script type="javascript" language="javascript">
                                   document.write(state);
                        </script>
                </font>
		...
	</div>
    </body>
</html>
Mi aspetterei di vedere una scritta rossa "ciao", cosa che in pratica non accade. Sapreste dirmi cosa sbaglio?
Player1 è offline   Rispondi citando il messaggio o parte di esso
Old 02-11-2010, 17:51   #2
MEMon
Senior Member
 
Iscritto dal: Dec 2002
Messaggi: 3359
Ciao, il type di uno script javascript corretto è "text/javascript".

Un consiglio, non utilizzare il document.write, inizia subito ad usare le potenzialità del DOM e usa solo uno script javascript nell' <head>, non sparsi per il codice html.
MEMon è offline   Rispondi citando il messaggio o parte di esso
Old 02-11-2010, 17:58   #3
Player1
Senior Member
 
Iscritto dal: Feb 2002
Messaggi: 1370
Grazie, il problema era proprio il type.
Per quanto riguarda il DOM ho letto poco a riguardo nelle guide che ho visto, potresti indicarmi qualche sito contenente una guida che fa uso di DOM?
Player1 è offline   Rispondi citando il messaggio o parte di esso
Old 02-11-2010, 18:11   #4
MEMon
Senior Member
 
Iscritto dal: Dec 2002
Messaggi: 3359
Quote:
Originariamente inviato da Player1 Guarda i messaggi
Grazie, il problema era proprio il type.
Per quanto riguarda il DOM ho letto poco a riguardo nelle guide che ho visto, potresti indicarmi qualche sito contenente una guida che fa uso di DOM?
C'è quella di html.it che per iniziare penso vada bene.

Poi per qualcosa di approfondito guarda le reference, ci sono sia quelle di javascript che quelle per il dom(e anche CSS ma se ne parlerà un pò più avanti).

Ti ho scritto un esempietto dal quale puoi iniziare a guardarti un paio di cose.
No n te l'ho commentato, lascio a te il divertimento di andarti a cercare come mai funziona così e cosa ho utilizzato.
Codice PHP:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<
html xmlns="http://www.w3.org/1999/xhtml">
<
head>
<
meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<
title>Documento senza titolo</title>
<
script type="text/javascript">

    function 
writeText(textcolor){
        var 
container=document.getElementById("container");
        
container.setAttribute("style""color:"+color);
        
container.innerHTML=text;
    }
    
    function 
init(){
        
writeText("Provaaaaaa""ORANGE");
    }

</script>
</head>
<body onload="init();">
    <div id="container"></div>
</body>
</html> 
MEMon è offline   Rispondi citando il messaggio o parte di esso
Old 03-11-2010, 08:28   #5
Player1
Senior Member
 
Iscritto dal: Feb 2002
Messaggi: 1370
Fantastico!
Ho appena finito di leggere la guida DOM e fare qualche prova!
Non pensavo che javascript con DOM fosse così flessibile e potente si possono davvero fare un sacco di cose con poco sforzo!

Ora però mi trovo di fronte ad un problema un po' più complesso.
Ho creato una semplicissima pagina in cui a sinistra c'è un menù con dei pulsanti ed a destra un <div id="content"> vuoto.

Vorrei fare in modo che alla pressione di un tasto il contenuto del div content caricasse una jsp, ho creato dunque una funzione javascript da associare ai vari pulsanti nel seguente modo:

Codice:
function contentSelector(buttonPressed){
	if (buttonPressed=='viewPageA'){
		pageContent = document.getElementById("content");
		pageContent.innerHTML = "<jsp:include page=\"pageA.jsp\" flush=\"true\" />";
	}
	...
}
Tuttavia alla pressione del pulsante non viene visualizzato nulla.
Credo di aver intuito che il problema è dovuto al fatto che javascript lavora sul browser e le jsp sul server quindi quando premo il pulsante il browser non possiede la jsp da visualizzare.
C'è un modo per indicare a javascript che deve richiedere al server il contenuto di content?
Preferirei non utilizzare forward, mi piacerebbe che la pagina fosse statica e cambiasse solo il contenuto di "content" in base alle situazioni (pressione dei pulsanti ecc.)
Player1 è offline   Rispondi citando il messaggio o parte di esso
Old 03-11-2010, 11:40   #6
MEMon
Senior Member
 
Iscritto dal: Dec 2002
Messaggi: 3359
Quote:
Originariamente inviato da Player1 Guarda i messaggi
Fantastico!
Ho appena finito di leggere la guida DOM e fare qualche prova!
Non pensavo che javascript con DOM fosse così flessibile e potente si possono davvero fare un sacco di cose con poco sforzo!

Ora però mi trovo di fronte ad un problema un po' più complesso.
Ho creato una semplicissima pagina in cui a sinistra c'è un menù con dei pulsanti ed a destra un <div id="content"> vuoto.

Vorrei fare in modo che alla pressione di un tasto il contenuto del div content caricasse una jsp, ho creato dunque una funzione javascript da associare ai vari pulsanti nel seguente modo:

Codice:
function contentSelector(buttonPressed){
	if (buttonPressed=='viewPageA'){
		pageContent = document.getElementById("content");
		pageContent.innerHTML = "<jsp:include page=\"pageA.jsp\" flush=\"true\" />";
	}
	...
}
Tuttavia alla pressione del pulsante non viene visualizzato nulla.
Credo di aver intuito che il problema è dovuto al fatto che javascript lavora sul browser e le jsp sul server quindi quando premo il pulsante il browser non possiede la jsp da visualizzare.
C'è un modo per indicare a javascript che deve richiedere al server il contenuto di content?
Preferirei non utilizzare forward, mi piacerebbe che la pagina fosse statica e cambiasse solo il contenuto di "content" in base alle situazioni (pressione dei pulsanti ecc.)
Se devi interagire con codice lato server devi utilizzare AJAX, che altro non è che javascript che fa richieste http al server.
keyword: ajax+jsp
MEMon è offline   Rispondi citando il messaggio o parte di esso
Old 09-11-2010, 15:07   #7
Player1
Senior Member
 
Iscritto dal: Feb 2002
Messaggi: 1370
Ciao!
Ho un nuovo problema con la gestione delle richieste asincrone.
La mia pagina è costituita da un menu a sinistra, ed un div centrale che rappresenta il contenuto.
Ogni volta che sul server c'è un aggiornamento il contenuto viene ricaricato, per farlo ho creato il seguente script:
Codice:
function monitorUpdate(page){
	monitor = new XMLHttpRequest();
	monitor.open("get", "./update",true)
	monitor.setRequestHeader("connection", "close");
	monitor.onreadystatechange = function() {
		if(monitor.readyState === 4) {
			execute(page);
		}
	}
	monitor.send(null);
}
In pratica monitor effettua la richiesta ma non riceve risposta finché non c'è un aggiornamento sul server, solo in quel momento esegue la funzione execute(page) che ricarica la pagina aggiornata nella quale tra l'altro è inclusa una nuova chiamata a monitor che di nuovo si mette in attesa e così via..
Fin qui tutto funziona correttamente.
Il problema si verifica quando clicco su un tasto del menù di sinistra per cambiare completamente il contenuto della pagina, poiché il "vecchio monitor" rimane comunque in attesa di un aggiornamento e, con la nuova pagina viene caricato un nuovo monitor contemporaneamente.
C'è un modo per chiudere monitor mentre è in attesa di onreadystatechange ?

Spero di essere stato abbastanza chiaro visto che il problema è un pò difficile da spiegare, se non lo sono stato, per favore, chiedete maggiori chiarimenti.
Player1 è offline   Rispondi citando il messaggio o parte di esso
Old 10-11-2010, 09:38   #8
MEMon
Senior Member
 
Iscritto dal: Dec 2002
Messaggi: 3359
Quote:
Originariamente inviato da Player1 Guarda i messaggi
Il problema si verifica quando clicco su un tasto del menù di sinistra per cambiare completamente il contenuto della pagina, poiché il "vecchio monitor" rimane comunque in attesa di un aggiornamento e, con la nuova pagina viene caricato un nuovo monitor contemporaneamente.
Prova a chiamare queste due righe di codice all'uscita della pagina, in modo da eliminare il vecchio monitor.
Codice:
monitor.onreadystatechange=null;
monito=null;
Oppure potresti pensare di assegnare ad ogni pagina un "codice" univoco, ad esempio creato a partire dai millisecondi, assegnarlo ai monitor che crei dentro la pagina e ogni volta che c'è la risposta del server verificare prima che il monitor abbia effettivamente il codice della pagina in cui si trova.
MEMon è offline   Rispondi citando il messaggio o parte di esso
Old 12-11-2010, 09:07   #9
Player1
Senior Member
 
Iscritto dal: Feb 2002
Messaggi: 1370
Quote:
Originariamente inviato da MEMon Guarda i messaggi
Prova a chiamare queste due righe di codice all'uscita della pagina, in modo da eliminare il vecchio monitor.
Codice:
monitor.onreadystatechange=null;
monito=null;
Ok sono riuscito a risolvere più o meno come mi hai suggerito, in realtà ho scoperto che per interrompere non bisogna usare onreadystatechange=null bensì monitor.abort().
In ogni caso volevo ringraziarti per la tua disponibilità, mi hai dato davvero un grande aiuto!
Player1 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Dreame X60 Pro Ultra Complete: i bracci si estendono sempre di più Dreame X60 Pro Ultra Complete: i bracci si esten...
TCL 65C8L, la recensione del SQD-Mini LED da 4400 nit misurati TCL 65C8L, la recensione del SQD-Mini LED da 440...
MSI Maestro 500 Wireless: ANC e 90 ore di autonomia a 70 euro MSI Maestro 500 Wireless: ANC e 90 ore di autono...
NL-LC1 è il primo dissipatore a liquido AIO di Noctua: silenzio è la parola d'ordine NL-LC1 è il primo dissipatore a liquido A...
Boox Go 10.3 (Gen II) Lumi: il tablet e-ink con Android 15 e penna, dal prezzo super Boox Go 10.3 (Gen II) Lumi: il tablet e-ink con ...
NVIDIA mostra una comunità di rob...
Sony annuncia LYTIA L910, arriva il sens...
Ericsson, il 5G è l’infrastruttur...
Marvell punta tutto su TSMC A14: sar&agr...
Hyundai a un passo dal controllo totale ...
Questo SSD vecchio 16 anni ha resistito ...
Monopattino elettrico Xiaomi in offerta:...
Microsoft usa le capre di Age of Empires...
Microsoft conferma bug nel Cestino in tu...
Accenture crolla del 20% in borsa, il pe...
ASUS Pro WS W890E-SAGE SE: sette PCIe 5....
Attenzione al prezzo di questa TV Hisens...
Chrome sbeffeggiato da Ballmer nel 2009:...
Un gioco Mac compatibile con Apple Silic...
La batteria allo stato solido di Honda s...
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:15.


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