HTML JavaScript

HTML JavaScript

The <script> element in HTML is used to add JavaScript code to web pages. JavaScript is a programming language that makes web pages interactive and dynamic.

Basic Usage:

You can use the <script> element to include JavaScript directly in your HTML file:

Output:
In this example:

⦁ <body>: Contains the visible content of the HTML document.
⦁ <h1>HTML JavaScript Example</h1>: Displays a heading with the text “HTML JavaScript Example”.
⦁ <script>: This element is used to embed or reference JavaScript code within the HTML document.
⦁ alert(‘Hello, world!’);: This JavaScript code inside the <script> tags triggers an alert dialog when the page is loaded. The alert() function displays a modal dialog box with the specified message (“Hello, world!” in this case).

External JavaScript File:

You can also link to an external JavaScript file using the src attribute:

Output:
In this example:

⦁ <head>: Contains meta-information about the document, such as the title and linked scripts.
⦁ <script src=”script.js”></script>: Includes the external JavaScript file script.js. The src attribute specifies the path to the JavaScript file.
⦁ <body>: Contains the visible content of the HTML document.
⦁ <h1>External JavaScript Example</h1>: Displays a heading with the text “External JavaScript Example”.
⦁ External JavaScript File (script.js):
⦁ alert(‘Hello, world!’);: This JavaScript code triggers an alert dialog with the message “Hello, world!”.

Attributes of <script>

Here is a table of the common <script> attributes

Attribute Description Example
src Specifies the URL of an external JavaScript file to be loaded and executed. <script src=”script.js”> </script>
type Defines the MIME type of the script. It’s usually text/javascript but is optional in HTML5. <script type=”text/javascript”>…</script>
defer Delays script execution until the HTML parsing is complete. <script src=”script.js” defer> .</script>
async Loads and executes the script asynchronously, without blocking HTML parsing. <script src=”script.js” async> </script>

JavaScript in Head vs. Body

Scripts can be placed in both the <head> and <body> sections of an HTML document. It’s often best to place scripts at the end of the <body> to prevent blocking the rendering of the page.

Example in <head>

<!DOCTYPE html>
<html>
<head>
    <title>Script in Head Example</title>
<script>
    alert(‘Hello from Head script!’);
</script>
</head>
<body>
    <h1>Welcome to My Website</h1>
</body>
</html>

Output
In this example:

⦁ <head>: Contains meta-information about the document, such as the title and embedded scripts.
⦁ <script>: This element is used to embed JavaScript code within the HTML document.
⦁ alert(‘Hello from Head script!’);: This JavaScript code inside the <script> tags triggers an alert dialog with the message “Hello from Head script!”.
⦁ <body>: Contains the visible content of the HTML document.
⦁ <h1>Welcome to My Website</h1>: Displays a heading with the text “Welcome to My Website”.

Example in <body>

<!DOCTYPE html>
<html>
<head>
    <title>Script in Body Example</title>
</head>
<body>
    <h1>Welcome to My Website</h1>
<script>
    alert(‘Hello from body script!’);
</script>
</body>
</html>

Output
In this example:

⦁ <body>: Contains the visible content of the HTML document.
⦁ <h1>Welcome to My Website</h1>: Displays a heading with the text “Welcome to My Website”.
⦁ <script>: This element is used to embed JavaScript code within the HTML document.
⦁ alert(‘Hello from body script!’);: This JavaScript code inside the <script> tags triggers an alert dialog with the message “Hello from body script!”.

Note: Placing scripts in the body, especially at the end, ensures that the HTML content loads first before executing the JavaScript.

Best Practices:

⦁ Place <script> tags just before the closing </body> tag to speed up page loading.
⦁ Use defer or async attributes to improve performance when loading external scripts.
⦁ Avoid inline scripts for better security; use external scripts whenever possible.

YouTube Reference :

Practice Scenarios

Scenario 1: Inline JavaScript Alert

Objective: Display an alert message when the page loads using inline JavaScript.
Expected Output: An alert box with the message “Welcome to the Inline JavaScript Example!” when the page loads.

<!DOCTYPE html>
<html>
<head>
    <title>Inline JavaScript Example</title>
</head>
<body>
    <h1>Inline JavaScript Example</h1>
<script>
    alert(‘Welcome to the Inline JavaScript Example!’);
</script>
</body>
</html>

Output:

Scenario 2: Inline JavaScript Alert with Styling

Objective: Display an alert message when the page loads using inline JavaScript, with styled HTML elements.
Expected Output: An alert box with the message “Welcome to the Inline JavaScript Example!” and styled content.

<!DOCTYPE html>
<html>
<head>
    <title>Inline JavaScript Example</title>
<style>
    body {
    font-family: Arial, sans-serif;
    background-color: #f0f0f0;
    text-align: center;
    padding-top: 50px;
    }
    h1 {
    color: #333;
    }
</style>
</head>
<body>
    <h1>Inline JavaScript Example</h1>
<script>
    alert(‘Welcome to the Inline JavaScript Example!’);
</script>
</body>
</html>

Output:

Scenario 3: External JavaScript File with Styling

Objective: Link to an external JavaScript file that displays an alert message when the page loads, with styled HTML elements.
Expected Output: An alert box with the message “Hello from the external JavaScript file!” and styled content.

Output:

Scenario 4: Script in Head Section with Styling

Objective: Place a script in the head section that displays an alert message when the page loads, with styled HTML elements.
Expected Output: An alert box with the message “Hello from body script!” and styled content.

Output:

Scenario 5: External JavaScript with Multiple Elements and Styling

Objective: Link to an external JavaScript file that interacts with multiple HTML elements, with styled HTML elements.
Expected Output: An alert box with the message “All elements are loaded!” when the page loads and additional interactions when buttons are clicked, with styled content.

Output: