DHTML: differenze tra le versioni

Contenuto cancellato Contenuto aggiunto
+{{Interfacce web}}
 
(58 versioni intermedie di 44 utenti non mostrate)
Riga 1:
Il '''DHTML''' (acronimo dall'inglese ''Dynamic [[HTML]]''), conosciuto anche come '''[[HTML]] dinamico''', è un insieme di tecnologie che permettono di cambiare in modo dinamico la rappresentazione e il contenuto di un documento ed aumentare l'interattività dell'utente sulla pagina.
{{stub_informatica}}
 
Il DHTML non è un linguaggio; consiste invece nell'uso di [[JavaScript]] per aggiungere funzionalità interattive a documenti HTML e fogli di stile [[CSS]].
Il '''DHTML''' (acronimo dall' inglese Dynamic [[HTML]]) , conosciuto anche come [[HTML]] Dinamico, è un'insieme di tecnologie che permettono di cambiare in modo dinamico la rappresentazione e il contenuto di un documento ed aumentare l'interittività dell'utente sulla pagina.
 
== Caratteristiche ==
Non è un vero e proprio linguaggio ma è una sorta di contenitore di script a cavallo tra il [[Javascript]], l'HTML e il [[CSS]].
[[File:Dhtml-schema.png|alt=Composizione di DHTML|miniatura|Composizione di DHTML]]
Gli elementi, gli attributi e gli stili del DHTML sono basati sull'HTML esistente e sulle specifiche classiche del [[W3C]].
Le caratteristiche più interessanti di questa tecnologia sono:
 
* dinamicità degli stili
Le caratteristiche più interessanti di questo linguaggio sono:
* dinamicità dei contenuti
 
* stile dinamico
* contenuto dinamico
* posizionamento e animazioni sugli elementi
* filtri e transizioni
* download di font non presenti sulla macchina
* data binding
* accesso facilitato al DOM (DHTML[[Document Object Model]])
 
=== Stile dinamico ===
 
Tramite il DHTML è possibile fare cambiare lo stile CSS di un oggetto in modo dinamico. Ad esempio:
<syntaxhighlight lang="html4strict">
<html>
<head>
<title>DHTML Test</title>
<script>function changeAll() { document.getElementById('div1').style.color = 'blue'; }</script>
</head>
<body>
<div id="div1" style="color: red;" onmouseover="changeAll()">
Benvenuti Nel test di DHTML! Passa sopra a questo testo!
</div>
</body>
</html>
</syntaxhighlight>
 
Oppure potremmo anche ordinare i dati presenti in una tabella cliccando in una determinata parte del documento: le potenzialità del linguaggio JavaScript sono molteplici, tanto che con un eloquente uso del linguaggio, si possono creare vere e proprie applicazioni web gestite direttamente dal browser, quindi senza necessità di supporto [[software]] da parte del [[client]].
 
== Struttura di una pagina web ==
In genere una pagina Web che utilizza DHTML viene impostata nel modo seguente:<syntaxhighlight lang="html">
<!DOCTYPE html>
<html lang="it">
<head>
<meta charset="utf-8">
<title>Esempio DHTML</title>
</head>
<body>
<div id="navigation"></div>
 
<script>
function init() {
var myObj = document.getElementById("navigation");
// ... manipola la finestra di myObj
}
window.onload = init;
</script>
 
<!--
Spesso il codice è memorizzato in un file esterno; questo viene fatto
collegando il file che contiene JavaScript.
Ciò è utile quando più pagine utilizzano lo stesso script:
-->
<script src="myjavascript.js"></script>
</body>
</html>
</syntaxhighlight>
 
== Visualizzazione di un blocco di testo aggiuntivo ==
Il codice seguente illustra una funzione usata spesso. Una parte aggiuntiva di una pagina web verrà visualizzata solo se l'utente lo richiede. Esempio:<syntaxhighlight lang="html">
 
<html>
<head>
<meta charset="utf-8">
<title>Utilizzo di una funzione DOM</title>
<style>
a { background-color: #eee; }
a:hover { background: #ff0; }
#toggleMe { background: #cfc; display: none; margin: 30px 0; padding: 1em; }
</style>
</head>
<body>
<h1>Utilizzo di una funzione DOM</h1>
<h2><a id="showhide" href="#">Mostra paragrafo</a></h2>
<p id="toggleMe">Questo è un paragrafo visibile solo se richiesto.</p>
<p>Il flusso generale del documento continua</p>
<script>
function changeDisplayState(id) {
var d = document.getElementById('showhide'),
e = document.getElementById(id);
if (e.style.display === 'none' || e.style.display === '') {
e.style.display = 'block';
d.innerHTML = 'Nascondo paragrafo';
} else {
e.style.display = 'none';
d.innerHTML = 'Mostra paragrafo';
}
}
document.getElementById('showhide').addEventListener('click', function (e) {
e.preventDefault();
changeDisplayState('toggleMe');
});
</script>
</body>
</html>
</syntaxhighlight>
 
== Stili dinamici ==
Utilizzando i CSS, è possibile modificare rapidamente l'aspetto e la formattazione degli elementi in un documento senza aggiungere o rimuovere elementi. Questo aiuta a mantenere i documenti piccoli e gli script che manipolano il documento velocemente. Esempio:<syntaxhighlight lang="html">
<!DOCTYPE html>
<html lang="it">
<head>
<meta charset="utf-8">
<title>Stili dinamici</title>
<style>
ul { display: none; }
</style>
</head>
 
<body>
<h1 id="firstHeader">Benvenuto nell' HTML dinamico</h1>
 
<p><a id="clickableLink" href="#">Gli stili dinamici sono una caratteristica fondamentale del DHTML.</a></p>
 
<ul id="unorderedList">
<li>Cambia il colore, la dimensione e il carattere tipografico del testo</li>
<li>Mostra e nascondi il testo/li>
<li>E molto, molto di più</li>
</ul>
 
<p>Siamo solo all'inizio!</p>
 
<script>
function showMe() {
document.getElementById("firstHeader").style.color = "#990000";
document.getElementById("unorderedList").style.display = "block";
}
 
document.getElementById("clickableLink").addEventListener("click", function (e) {
e.preventDefault();
showMe();
});
</script>
</body>
</html>
</syntaxhighlight>
 
== StileVoci Dinamicocorrelate ==
* [[HTML]]
* [[CSS]]
* [[JavaScript]]
 
== Collegamenti esterni ==
Tramite il DHTML è possibile fare cambiare lo stile CSS di un oggetto in modo dinamico. Ad esempio
* {{Collegamenti esterni}}
<HTML>
* [http://www.mah-jongg.ch Esempio: Mahjongg solitario] gioco popolare scritto in DHTML
<HEAD><TITLE>Dynamic Styles</TITLE>
<SCRIPT LANGUAGE="JScript">
function doChanges() {
window.event.srcElement.style.color = "green";
window.event.srcElement.style.fontSize = "20px";
}
</SCRIPT>
</HEAD>
<BODY>
<!-- Substitute xxx with DIV -->
<xxx ID=heading onmouseover="doChanges()" STYLE="color:black;font-size:18">Welcome to Dynamic HTML!
You can do the most amazing things with the least bit of effort.
</xxx>
</BODY>
</HTML>
 
{{Interfacce web}}
[[Categoria:Linguaggi di markup]]
{{Controllo di autorità}}
[[Categoria:Internet]]
{{Portale|Telematica}}
[[Categoria:Acronimi]]
 
[[deCategoria:Dynamic HTML]]
[[en:Dynamic HTML]]
[[es:HTML dinámico]]
[[fr:HTML dynamique]]
[[he:DHTML]]
[[ja:ダイナミックHTML]]
[[ko:DHTML]]
[[nl:Dynamic HTML]]
[[pl:Dynamiczny HTML]]
[[pt:Dynamic HTML]]