Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Test ride con Gowow Ori: elettrico e off-road vanno incredibilmente d'accordo
Test ride con Gowow Ori: elettrico e off-road vanno incredibilmente d'accordo
Abbiamo provato per diversi giorni una new entry del mercato italiano, la Gowow Ori, una moto elettrica da off-road, omologata anche per la strada, che sfrutta una pendrive USB per cambiare radicalmente le sue prestazioni
Recensione OnePlus 15: potenza da vendere e batteria enorme dentro un nuovo design
Recensione OnePlus 15: potenza da vendere e batteria enorme dentro un nuovo design
OnePlus 15 nasce per alzare l'asticella delle prestazioni e del gaming mobile. Ma non solo, visto che integra un display LTPO 1,5K a 165 Hz, OxygenOS 16 con funzioni AI integrate e un comparto foto con tre moduli da 50 MP al posteriore. La batteria da 7.300 mAh con SUPERVOOC 120 W e AIRVOOC 50 W è la ciliegina sulla torta per uno smartphone che promette di offrire un'esperienza d'uso senza alcun compromesso
AMD Ryzen 5 7500X3D: la nuova CPU da gaming con 3D V-Cache per la fascia media
AMD Ryzen 5 7500X3D: la nuova CPU da gaming con 3D V-Cache per la fascia media
Vediamo come si comporta il Ryzen 5 7500X3D, nuovo processore di casa AMD che fonde 6 core Zen 4 con la tecnologia 3D V-Cache, particolarmente utile in scenari come il gaming. Annunciato a un prezzo di listino di 279€, il nuovo arrivato sarà in grado di diventare un riferimento per i sistemi budget? Ecco cosa ne pensiamo.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 02-11-2010, 18: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, 18: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, 18: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, 19: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, 09: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, 12: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, 16: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, 10: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, 10: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


Test ride con Gowow Ori: elettrico e off-road vanno incredibilmente d'accordo Test ride con Gowow Ori: elettrico e off-road va...
Recensione OnePlus 15: potenza da vendere e batteria enorme dentro un nuovo design   Recensione OnePlus 15: potenza da vendere e batt...
AMD Ryzen 5 7500X3D: la nuova CPU da gaming con 3D V-Cache per la fascia media AMD Ryzen 5 7500X3D: la nuova CPU da gaming con ...
SONY BRAVIA 8 II e BRAVIA Theatre System 6: il cinema a casa in formato compatto SONY BRAVIA 8 II e BRAVIA Theatre System 6: il c...
KTC H27E6 a 300Hz e 1ms: come i rivali ma a metà prezzo KTC H27E6 a 300Hz e 1ms: come i rivali ma a met&...
4,9 miliardi su Google: Buffett sfida il...
Google ha svelato un agente AI che può g...
Tesla cambia idea: è in arrivo l'...
Anche Firefox punta sull'intelligenza ar...
Stop alle super-accelerazioni delle auto...
Osservatorio AGCOM: sempre più ac...
Sempre più IA su Spotify: arrivan...
iMac M4 crolla a 1.199€ con risparmio di...
Nintendo Switch 2: in rilascio un nuovo ...
Core Ultra 9 290K Plus, Core Ultra 7 270...
Prezzo Black Friday per le super cuffie ...
Crollano i prezzi della cuffie Beats col...
ASUS ROG Matrix RTX 5090 costa 4000 doll...
Grazie ai dati di ESA il calcolo della t...
Rilasciati nuovi video e immagini della ...
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: 18:42.


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