Determining Device Width in JavaScript
Introduction
Capturing the device's actual width, as opposed to the viewport width, is a common requirement in JavaScript development. CSS media queries provide this capability through the max-device-width property. However, bridging this functionality to JavaScript remains a challenge.
Device Width vs. Viewport Width
Viewport width pertains to the visible portion of the page within the browser window. Device width, on the other hand, represents the entire physical screen size of the device. This distinction becomes crucial when creating responsive designs, especially when catering to smartphones in landscape orientation.
JavaScript Solution
To obtain the device width in JavaScript, use the screen.width property:
var deviceWidth = screen.width;
In some cases, particularly with desktop browsers, window.innerWidth may provide a more accurate measurement:
var windowWidth = window.innerWidth;
For scenarios involving both desktop browsers and mobile devices, a comprehensive solution is to combine both measurements:
var width = (window.innerWidth > 0) ? window.innerWidth : screen.width;
This approach ensures the correct device width regardless of the device or browser type.
The above is the detailed content of How Can I Get the Actual Device Width in JavaScript?. For more information, please follow other related articles on the PHP Chinese website!

In this post, Blackle Mori shows you a few of the hacks found while trying to push the limits of Cohost’s HTML support. Use these if you dare, lest you too get labelled a CSS criminal.

Custom cursors with CSS are great, but we can take things to the next level with JavaScript. Using JavaScript, we can transition between cursor states, place dynamic text within the cursor, apply complex animations, and apply filters.

Interactive CSS animations with elements ricocheting off each other seem more plausible in 2025. While it’s unnecessary to implement Pong in CSS, the increasing flexibility and power of CSS reinforce Lee's suspicion that one day it will be a

Tips and tricks on utilizing the CSS backdrop-filter property to style user interfaces. You’ll learn how to layer backdrop filters among multiple elements, and integrate them with other CSS graphical effects to create elaborate designs.

Well, it turns out that SVG's built-in animation features were never deprecated as planned. Sure, CSS and JavaScript are more than capable of carrying the load, but it's good to know that SMIL is not dead in the water as previously

Yay, let's jump for text-wrap: pretty landing in Safari Technology Preview! But beware that it's different from how it works in Chromium browsers.

This CSS-Tricks update highlights significant progress in the Almanac, recent podcast appearances, a new CSS counters guide, and the addition of several new authors contributing valuable content.

Most of the time, people showcase Tailwind's @apply feature with one of Tailwind's single-property utilities (which changes a single CSS declaration). When showcased this way, @apply doesn't sound promising at all. So obvio


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

WebStorm Mac version
Useful JavaScript development tools

MantisBT
Mantis is an easy-to-deploy web-based defect tracking tool designed to aid in product defect tracking. It requires PHP, MySQL and a web server. Check out our demo and hosting services.

ZendStudio 13.5.1 Mac
Powerful PHP integrated development environment

SublimeText3 Chinese version
Chinese version, very easy to use

PhpStorm Mac version
The latest (2018.2.1) professional PHP integrated development tool
