Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Roborock Saros 20: il robot preciso e molto sottile
Roborock Saros 20: il robot preciso e molto sottile
Il nuovo robot di Roborock per l'aspirazione della polvere e il lavaggio dei pavimenti spicca per immediatezza d'uso e per l'efficacia dell'azione, grazie anche a un ridotto sviluppo in altezza. Saros 20 integra un motore da ben 36.000Pa di potenza e un sistema di lavaggio a due panni rotanti, con bracci estensibili e un sistema di navigazione molto preciso.
ASUS ROG Kithara: quando HIFIMAN incontra il gaming con driver planari da 100mm
ASUS ROG Kithara: quando HIFIMAN incontra il gaming con driver planari da 100mm
ASUS e HIFIMAN uniscono le forze per creare ROG Kithara, cuffie gaming con driver magnetici planari da 100mm, design open-back e microfono MEMS full-band. Una proposta che ambisce a coniugare fedeltà per audiofili e performance ludiche, disponibili a 319 euro
Roborock Qrevo Curv 2 Flow: ora lava con un rullo
Roborock Qrevo Curv 2 Flow: ora lava con un rullo
Qrevo Curv 2 Flow è l'ultima novità di casa Roborock per la pulizia di casa: un robot completo, forte di un sistema di lavaggio dei pavimenti basato su rullo che si estende a seguire il profilo delle pareti abbinato ad un potente motore di aspirazione con doppia spazzola laterale
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


Roborock Saros 20: il robot preciso e molto sottile Roborock Saros 20: il robot preciso e molto sott...
ASUS ROG Kithara: quando HIFIMAN incontra il gaming con driver planari da 100mm ASUS ROG Kithara: quando HIFIMAN incontra il gam...
Roborock Qrevo Curv 2 Flow: ora lava con un rullo Roborock Qrevo Curv 2 Flow: ora lava con un rull...
Alpine A290 alla prova: un'auto bella che ti fa innamorare, con qualche limite Alpine A290 alla prova: un'auto bella che ti fa ...
Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile Recensione HONOR Magic 8 Lite: lo smartphone ind...
Xiaomi 17 in arrivo: parte il conto alla...
Rapidus incassa 1,7 miliardi di dollari ...
Parcheggi in città senza pensieri...
IA e crisi sistemica: perché tre ...
Le migliori offerte Amazon del weekend, ...
Offerte smartphone Amazon: sono 12 fra c...
Lefant a 139€ o roborock a 149€? Solo 10...
160 campi da calcio di server: l'impatto...
210€ risparmiate su MacBook Air in offer...
Google Pixel 10a, il prezzo scende subit...
Lockheed Martin testa l'AI sull'F-35 Lig...
La missione NASA Lunar Trailblazer &egra...
Gli astronauti di Artemis II utilizzeran...
Una parte del razzo spaziale SpaceX Star...
Phanteks Glacier One 360M25-LCD: raffred...
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: 12:37.


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