- HTML Tutorial
- HTML - Home
- HTML - Introduction
- HTML - Editors
- HTML - Basic Tags
- HTML - Elements
- HTML - Attributes
- HTML - Headings
- HTML - Paragraphs
- HTML - Fonts
- HTML - Blocks
- HTML - Style Sheet
- HTML - Formatting
- HTML - Quotations
- HTML - Comments
- HTML - Colors
- HTML - Images
- HTML - Image Map
- HTML - Iframes
- HTML - Phrase Elements
- HTML - Meta Tags
- HTML - Classes
- HTML - IDs
- HTML - Backgrounds
- HTML Tables
- HTML - Tables
- HTML - Headers & Caption
- HTML - Table Styling
- HTML - Table Colgroup
- HTML - Nested Tables
- HTML Lists
- HTML - Lists
- HTML - Unordered Lists
- HTML - Ordered Lists
- HTML - Definition Lists
- HTML Links
- HTML - Text Links
- HTML - Image Links
- HTML - Email Links
- HTML Color Names & Values
- HTML - Color Names
- HTML - RGB
- HTML - HEX
- HTML - HSL
- HTML Forms
- HTML - Forms
- HTML - Form Attributes
- HTML - Form Control
- HTML - Input Attributes
- HTML Media
- HTML - Video Element
- HTML - Audio Element
- HTML - Embed Multimedia
- HTML Header
- HTML - Head Element
- HTML - Adding Favicon
- HTML - Javascript
- HTML Layouts
- HTML - Layouts
- HTML - Layout Elements
- HTML - Layout using CSS
- HTML - Responsiveness
- HTML - Symbols
- HTML - Emojis
- HTML - Style Guide
- HTML Graphics
- HTML - SVG
- HTML - Canvas
- HTML APIs
- HTML - Geolocation API
- HTML - Drag & Drop API
- HTML - Web Workers API
- HTML - WebSocket
- HTML - Web Storage
- HTML - Server Sent Events
- HTML Miscellaneous
- HTML - MathML
- HTML - Microdata
- HTML - IndexedDB
- HTML - Web Messaging
- HTML - Web CORS
- HTML - Web RTC
- HTML Demo
- HTML - Audio Player
- HTML - Video Player
- HTML - Web slide Desk
- HTML Tools
- HTML - Velocity Draw
- HTML - QR Code
- HTML - Modernizer
- HTML - Validation
- HTML - Color Picker
- HTML References
- HTML - Cheat Sheet
- HTML - Tags Reference
- HTML - Attributes Reference
- HTML - Events Reference
- HTML - Fonts Reference
- HTML - ASCII Codes
- ASCII Table Lookup
- HTML - Color Names
- HTML - Entities
- MIME Media Types
- HTML - URL Encoding
- Language ISO Codes
- HTML - Character Encodings
- HTML - Deprecated Tags
- HTML Resources
- HTML - Quick Guide
- HTML - Useful Resources
- HTML - Color Code Builder
- HTML - Online Editor
HTML - Responsive Web Design
A Responsive Web design all about designing a webpage that looks good in all the end user devices like phones, tablets and desktops. It will automatically adjust size and other features accordance with user device.
Responsive Webpages help in improving the user experience, accessibility and performance of a website.
How to make Responsive Webpages?
There are several ways by which we can make our webpage responsive. A general practice is to make use of inbuilt CSS or bootstrap frameworks that provide pre-designed components and grid systems. Here are some general steps to ensure responsiveness of a webpage.
- Use Responsive Grid Layouts
Always design your layout with a flexible grid structure, so when the size of screen increases grid will extend accordingly. - Flexible Images and Media
Ensure that the images in webpage as properly scaled within their containers. You can use CSS properties like "max-width: 100%;" and "height: auto;". - Use Media Query
You can use CSS media queries to apply different styles for different screen sizes. This allows you to adjust the layout, font sizes, and other design elements based on the device's width. You can know about media query here. - Include Meta Tag with viewport
The viewport meta tag inside HTML head to ensures proper scaling and rendering on mobile devices. - Use Relative Units
Use relative units like em, rem, or percentages for font sizes, padding, and margins to ensure that text scales appropriately.
Setting Viewport for Responsive Design
The viewport represents the visible area of user's device. The content that is outside of the viewport can be seen if scrolled. It helps web pages’ render well on different devices by controlling the width and scale of the page.
To control the viewport, add the following <meta> tag in the <head> section:
<meta name="viewport" content="width=device-width, initial-scale=1.0">
The above tag tells the browser to match the page width to the screen's width and set the initial zoom level when the page is first loaded by the user.
We can adjust viewport settings for width, initial-scale, maximum-scale, minimum-scale, and user-scalable. These adjustments can make our website more accessible and user-friendly.
HTML <meta> viewport tag Attributes
The following attributes of <meta> viewport tag are used for responsiveness:
Attribute | Description |
---|---|
width | It controls the width of the virtual viewport. |
height | It controls the height of the virtual viewport. |
initial-scale | It specifies the initial zoom level of the viewport when a web page is first loaded. |
minimum-scale | It specifies the minimum zoom level to which the user can zoom the page. |
maximum-scale | It defines the maximum zoom level to which the user can zoom the page. |
user-scalable | It specifies whether the user can zoom in or out. |
interactive-widget | It defines how the interactive UI widgets affect the viewport. |
Examples of Responsive Webpages
Here are some examples of responsive webpage designing using HTML and CSS. Checkout the below examples to clear your concept on responsive web design.
Setting Viewport for Webpage
The following example illustrates how to use the <meta> viewport tag to make a web page responsive.
<html> <head> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <style> .container { background-color: #f1f1f1; display: flex; flex-direction: row; } .col { width: 47%; margin: auto 1%; background-color: #4CAF50; color: white; text-align: center; line-height: 100px; font-size: 10px; } </style> </head> <body> <h2> Setting up dimensions in percentage for the HTML element </h2> <div class="container"> <div class="col"> Column 1 </div> <div class="col"> Column 2 </div> </div> </body> </html>
Creating Responsive Text
In HTML, to make a responsive text that adjusts its font size automatically based on the viewport, we need to use the font-size property of CSS along with "vw" length unit. The vw is an abbreviation that stands for view width or viewport width which is a relative length unit of CSS.
The relative length units are always calculated with respect to another element's size. Note that 1vw is equal to 1% of the width of viewport.
In this example, we are using the "vw" length unit to make the text responsive.
<html> <head> <meta name="viewport" content="width=device-width, initial-scale=1.0"> </head> <body> <h1 style="font-size:6vw;"> Example of Responsive Typography </h1> <h2 style="font-size:5vw;"> Responsive text by Using the vw length unit. </h2> <p style="font-size:3vw;"> The text will adapt the font size according to the device's width. </p> </body> </html>
Creating Responsive Images
In HTML, we can create images that are responsive, meaning they can adjust their size to fit the viewport. To do so, we can either set the image's width property to 100% or max-width property to 100%. The width property can scale the image larger than its original size, on the other hand, the max-width property ensures the image does not scale beyond its original size.
The following example shows how to create responsive images. For the first image, we are using the width property and for the second one max-width property.
<html> <head> <meta name="viewport" content="width=device-width, initial-scale=1.0"> </head> <body> <h2> Setting the width property to 100% </h2> <img src="/images/logo.png" alt="logo" style="width:100%; "> <h2> Creating the responsive image by setting the max-width property to 100% </h2> <img src="/images/logo.png" alt="logo" style="max-width:100%; height:auto; "> </body> </html>
Responsive design using Media Queries
The CSS media query serves as a filter that enables us to style the web page selectively for different devices. A single web page can have multiple media queries, each for a specific screen size. To define these screen sizes, we use the media query breakpoints and style the HTML elements accordingly. Here are the common breakpoints:
- Mobile: 360 x 640 px
- Tablet: 768 x 1024 px
- Laptop: 1366 x 768 px
- HDdesktop: 1920 x 1080 px
The following HTML code demonstrates the use of media queries in designing a responsive layout.
<html> <head> <style> .main { width: 50%; height: 50vh; display: flex; align-items: center; text-align: center; margin: 10px auto; flex-direction: column; } img { width: 100%; height: 100%; } .description { width: 100%; height: 100%; font-size: 30px; color: red; margin-top: 20px; } /* using media query */ @media screen and (max-width: 600px) { .main { width: 100%; height: 100vh; margin: 5px auto; } .description { font-size: 20px; color: blue; margin-top: 10px; } } </style> </head> <body> <div class="main"> <img src="/images/logo.png" alt="logo" width="100" height="200"> <div class="description"> The above is a logo of Tutorilaspoint. The logo is responsive, and it will be displayed in the centre of the screen. </div> </div> </body> </html>
Responsive Flexbox Layout
The below example will make a responsive webpage using flexbox layout. The sidebar will remain on top for devices with screen width less than 768 pixels.
<!DOCTYPE html> <html lang="en"> <head> <title> Responsive Flexbox Layout </title> <style> * { box-sizing: border-box; margin: 0; padding: 0; } body { font-family: sans-serif; line-height: 1.6; } .header, .footer { background-color: #333; color: white; text-align: center; padding: 1rem; } .container { display: flex; flex-wrap: wrap; min-height: 80vh; } .sidebar { background: #f4f4f4; flex: 1; min-width: 200px; padding: 1rem; } .main-content { background: #fff; flex: 3; padding: 1rem; min-width: 300px; } .footer { margin-top: auto; } @media (max-width: 768px) { .container { flex-direction: column; } } </style> </head> <body> <header class="header"> <h1>Header</h1> </header> <div class="container"> <aside class="sidebar"> <h2>Sidebar</h2> <p>Sidebar content goes here.</p> </aside> <main class="main-content"> <h2>Main Content</h2> <p>Main content goes here.</p> <p> Resize output window to see responsiveness. </p> </main> </div> <footer class="footer"> <p>Footer</p> </footer> </body> </html>