bg_image
header

Dynamic HTML - DHTML

Dynamic HTML (DHTML) is a combination of technologies used to create interactive and dynamic web content. It’s not a standalone standard or programming language but rather a collection of techniques and tools that work together. DHTML enables websites to update content dynamically and provide interactivity without reloading the entire page.

Components of DHTML

  1. HTML (Hypertext Markup Language)
    Provides the basic structure of the webpage.

  2. CSS (Cascading Style Sheets)
    Controls the appearance and layout of the webpage. CSS can be dynamically altered to create effects like hover states or style changes.

  3. JavaScript
    Adds interactivity and dynamic behavior, such as updating content without a page reload.

  4. DOM (Document Object Model)
    A programming interface that allows access to and manipulation of the webpage’s structure. JavaScript interacts with the DOM to change content or add new elements.

What makes DHTML special?

  • Interactivity: Content and styles respond to user input.
  • Animations: Elements like text or images can move or animate.
  • Dynamic Content Updates: Parts of the webpage can change without reloading.
  • Improved User Experience: Offers real-time actions for users.

Example of DHTML

Here’s a simple example of a button changing text dynamically:

<!DOCTYPE html>
<html>
<head>
    <style>
        #text {
            color: blue;
            font-size: 20px;
        }
    </style>
    <script>
        function changeText() {
            document.getElementById("text").innerHTML = "Text changed!";
            document.getElementById("text").style.color = "red";
        }
    </script>
</head>
<body>
    <p id="text">Original text</p>
    <button onclick="changeText()">Click me</button>
</body>
</html>

Advantages of DHTML:

  • Increases interactivity and dynamism on a website.
  • Reduces server load as fewer page reloads are needed.
  • Allows for personalized user experiences.

Disadvantages:

  • May cause compatibility issues with older browsers or devices.
  • Requires more development effort and complex debugging.
  • Relies on JavaScript, which some users may disable.

Nowadays, DHTML has been largely replaced by modern techniques like AJAX and frameworks (e.g., React, Vue.js). However, it was a crucial step in the evolution of interactive web applications.

 

 


Document Object Model - DOM

The Document Object Model (DOM) is a standardized interface provided by web browsers to represent and programmatically manipulate structured documents, especially HTML and XML documents. It describes the hierarchical structure of a document as a tree, where each node represents an element, attribute, or text.

Key Features of the DOM:

  1. Tree Structure:

    • An HTML document is represented as a hierarchical tree. The root is the <html> element, with child nodes such as <head>, <body>, <div>, <p>, etc.
  2. Object-Oriented Representation:

    • Each element in the document is represented as an object that can be accessed and modified through methods and properties.
  3. Interactivity:

    • The DOM allows developers to modify content and styles of a webpage at runtime. For instance, JavaScript scripts can change the text of a <p> element or insert a new <div>.
  4. Platform and Language Agnostic:

    • Although commonly used with JavaScript, the DOM can also be manipulated using other languages like Python, Java, or PHP.

Examples of DOM Manipulation:

1. Accessing an Element:

let element = document.getElementById("myElement");

2. Changing Content:

element.textContent = "New Text";

3. Adding a New Element:

let newNode = document.createElement("div");
document.body.appendChild(newNode);

Important Note:

The DOM is defined and maintained by the W3C (World Wide Web Consortium) standards and is constantly updated to support modern web technologies.

 

 

 


Extensible Hypertext Markup Language - XHTML

XHTML (Extensible Hypertext Markup Language) is a variant of HTML (Hypertext Markup Language) that is based on XML (Extensible Markup Language). XHTML combines the flexibility of HTML with the strictness and structure of XML. Here are some key aspects and features of XHTML:

  1. Structure and Syntax:

    • Well-formedness: XHTML documents must be well-formed, meaning they must adhere to all XML rules. This includes correctly nested and closed tags.
    • Elements and Attributes: All elements and attributes in XHTML must be written in lowercase.
    • Closing Tags: All tags must be closed, either with a corresponding end tag (e.g., <p></p>) or as self-closing tags (e.g., <img />).
  2. Compatibility:

    • XHTML is designed to be backward compatible with HTML. Many web browsers can render XHTML documents even if they were initially developed for HTML documents.
    • XHTML documents are treated as XML documents, meaning they can be parsed by XML parsers. This facilitates the integration of XHTML with other XML-based technologies.
  3. Doctype Declaration:

    • An XHTML document begins with a doctype declaration that specifies the document type and the version of XHTML being used. For example:
      <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
  4. Practical Use:

    • XHTML was developed to address the shortcomings of HTML and provide a stricter structure that improves document interoperability and processing.
    • Although XHTML offers many advantages, it has not been fully adopted. HTML5, the latest version of HTML, incorporates many of XHTML's benefits while maintaining the flexibility and ease of use of HTML.
  5. Different XHTML Profiles:

    • XHTML 1.0: The first version of XHTML, offering three different DTDs (Document Type Definitions): Strict, Transitional, and Frameset.
    • XHTML 1.1: An advanced version of XHTML that provides a more modular structure and better support for international applications.
    • XHTML Basic: A simplified version of XHTML specifically designed for mobile devices and other limited environments.

In summary, XHTML is a stricter and more structured variant of HTML based on XML, offering advantages in certain application areas. It was developed to improve web interoperability and standardization but has not been fully adopted due to the advent of HTML5.