Table des matières
回复内容:
Maison interface Web Tutoriel H5 像素和CSS媒体查询?

像素和CSS媒体查询?

Jun 07, 2016 am 08:42 AM
css div min width

我们知道像素是一个相对单位,不是一个拥有固定大小的点单位。但我想请问:在CSS中媒体查询用到的PX究竟是怎样一个单位?乃至我想问:在CSS中,像素是否已经不再是一个相对单位,而是一个拥有固定宽度的单位?

举例:

我用媒体查询 @media (min- width: 1200px) {……}这样的语句来控制在大于1200px的屏幕才显示某个DIV。

我用手机访问这个页面时,此DIV却不显示,但我的手机分辨率是1920*1080,按道理讲是满足min- width: 1200px这条件的,但为什么不显示呢?

难道PX是拥有固定长度的单位?

谢谢解答!

回复内容:

其实几句话就说明白了呀.......
css里所有的px都是css pixel,其显示大小是相对的而不是绝对的,是设备相关的。
而css pixel * devicePixelRatio = 实际屏幕像素。
(平时电脑屏幕的devicePixelRatio都是1所以感觉不到,会让你误以为css里的px就是实际屏幕像素)
同时media query使用的px显然也是css pixel。

可以用chrome按f12开emulator看,一目了然。
像素和CSS媒体查询?模拟器里有很型号可以选择,比如Nexus 5, iPhone等等
像素和CSS媒体查询?
下图左边的就是css pixel, 右边是devicePixelRatio
像素和CSS媒体查询? 像素和CSS媒体查询?如图,Nexus 5的css pixel是360x640,devicePixelRatio是3,实际屏幕尺寸就是(360*3)x(640*3)=1080x1920 (实际上应该根据屏幕尺寸和devicePixelRatio来反推css pixel)
可以看到大部分安卓设备的css pixel尺寸都是360x640

你可以这么简单理解:
不管是1080x1920的屏幕还是720x1280的屏幕,对于移动端浏览器来说,尺寸都是360x640
所以,写css的时候以css pixel为准,也就是说:假设设计图做成了720x1280的,那么css里所有尺寸都除以2即可。
而对于图片,比如一张实际大小100*100px的图片,并且width和height都设了100px(注意这里的px是css pixel),实际占用了屏幕的像素数就是(假设devicePixelRatio是3)300*300px(注意这里的px是真实的屏幕像素)
所以,如果希望网页的元素在高ppi设备上显示不模糊(比如1080x1920屏幕的手机),位图应该做3倍的尺寸(比如做300*300px的图,然后在css中设width和height为100px),svg(矢量图)就无所谓了。
(所以svg大法好!png都是异端!)




因此在你的例子中,应该写min-width:400px
同时最好加上
(绝大部分1080x1920屏幕的设备devicePixelRatio都是3,1200/3=400) 像素和CSS媒体查询?
手机浏览器会找你的,如果指定了width,就会把页面放到指定width的viewport里面取,如果没有指定,则默认值有的是980,具体根据浏览器来定的。
送你一个文档链接:Using the viewport meta tag to control layout on mobile browsers
还有像素的问题:
此像素非彼像素A pixel is not a pixel is not a pixel 因为大多数1920*1080的手机上是把网页当成 640*360 缩小三倍显示处理的,所以生效的其实是360这个宽度 搜一下关键词 window.devicePixelRatio 前面几个答案从实际应用层面解答了,不过我想了下你的疑问是针对单位的,那么从“像素是一个相对单位”这句话入手做个解答吧。

一、像素的显示定义
像素,即图像元素的基本单位。
分辨率,即屏幕图像的精密度,是指显示屏所能显示的像素的多少。

对网页开发者来说,像素的概念多启蒙于桌面显示器,并且基本只需要知道这一单位。当跨屏到其他设备时,会有难以理解的诸多单位相关概念出现,如dp\dpi\ppi等进而产生混乱,从硬件屏幕的显示差异入手理解会清晰一些。

我们知道,图像显示需要媒介,有如台式机、手机、相机和纸张实物等。像素基于图像, 屏幕分辨率基于像素,而跨屏设备的屏幕分辨率与物理尺寸无关(是的无关),因此在电子设备上,像素是一个纯电子尺寸而非物理尺寸。

也就是说呢,跨屏设备的分辨率像素之间是存在物理差异的。举个栗子,同为1280分辨率宽的桌面显示器与三星NOTE,一个是17",宽为13.27"(33.72cm);一个是5.3",宽为4.49"(11.42cm)。一个像素单位所占的物理空间分别为:33.72/1280 = 0.02634(cm) 与 11.42/1280=0.0089(cm),相差3倍。

二、手机浏览器的逻辑分辨率与媒体查询
(逻辑分辨率称为逻辑pt分辨率会更为精确,这里为便于理解暂且忽略pt)
手机厂商会提供一个分辨率如三星NOTE为1280*800(物理分辨率),但此分辨率通常不是手机网页浏览器的渲染尺寸,这是因为手机网页浏览器是以逻辑分辨率进行渲染的,而逻辑分辨率=物理分辨率/devicePixelRatio

普通密度桌面显示屏的devicePixelRatio=1
高密度桌面显示屏(Mac Retina)的devicePixelRatio=2
主流手机显示屏的devicePixelRatio=2或3
Copier après la connexion
手机不应该是1080x1920吗 这个,,,你先用图片测试一下你的道理正确吗?试一试一张1200px的图片在你当前页面怎么显示的
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Où trouver la courte de la grue à atomide atomique
1 Il y a quelques semaines By DDD

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Comment utiliser le bouton bootstrap Comment utiliser le bouton bootstrap Apr 07, 2025 pm 03:09 PM

Comment utiliser le bouton bootstrap? Introduisez Bootstrap CSS pour créer des éléments de bouton et ajoutez la classe de bouton bootstrap pour ajouter du texte du bouton

Comment redimensionner le bootstrap Comment redimensionner le bootstrap Apr 07, 2025 pm 03:18 PM

Pour ajuster la taille des éléments dans Bootstrap, vous pouvez utiliser la classe de dimension, qui comprend: ajuster la largeur: .col-, .w-, .mw-ajustement Hauteur: .h-, .min-h-, .max-h-

Comment télécharger des fichiers sur bootstrap Comment télécharger des fichiers sur bootstrap Apr 07, 2025 pm 01:09 PM

La fonction de téléchargement de fichiers peut être implémentée via Bootstrap. Les étapes sont les suivantes: introduire les fichiers Bootstrap CSS et JavaScript; créer des champs d'entrée de fichier; créer des boutons de téléchargement de fichiers; gérer les téléchargements de fichiers (à l'aide de FormData pour collecter des données, puis envoyer au serveur); style personnalisé (facultatif).

Comment insérer des photos sur bootstrap Comment insérer des photos sur bootstrap Apr 07, 2025 pm 03:30 PM

Il existe plusieurs façons d'insérer des images dans Bootstrap: insérer directement les images, en utilisant la balise HTML IMG. Avec le composant d'image bootstrap, vous pouvez fournir des images réactives et plus de styles. Définissez la taille de l'image, utilisez la classe IMG-FLUID pour rendre l'image adaptable. Réglez la bordure en utilisant la classe IMG-border. Réglez les coins arrondis et utilisez la classe Roundée IMG. Réglez l'ombre, utilisez la classe Shadow. Redimensionner et positionner l'image, en utilisant le style CSS. À l'aide de l'image d'arrière-plan, utilisez la propriété CSS d'image d'arrière-plan.

Comment supprimer le style par défaut dans la liste Bootstrap? Comment supprimer le style par défaut dans la liste Bootstrap? Apr 07, 2025 am 10:18 AM

Le style par défaut de la liste bootstrap peut être supprimé avec CSS Override. Utilisez des règles et sélecteurs CSS plus spécifiques, suivez le «principe de proximité» et le «principe de poids», en remplacement du style par défaut de bootstrap. Pour éviter les conflits de style, des sélecteurs plus ciblés peuvent être utilisés. Si le remplacement est infructueux, ajustez le poids du CSS personnalisé. Dans le même temps, faites attention à l'optimisation des performances, évitez la surutilisation de! Importante et écrivez le code CSS concis et efficace.

Comment changer la taille d'une liste de bootstrap? Comment changer la taille d'une liste de bootstrap? Apr 07, 2025 am 10:45 AM

La taille d'une liste d'amorçage dépend de la taille du conteneur qui contient la liste, pas de la liste elle-même. L'utilisation du système de grille de bootstrap ou de Flexbox peut contrôler la taille du conteneur, redimentant ainsi indirectement les éléments de la liste.

Comment disposer bootstrap Comment disposer bootstrap Apr 07, 2025 pm 02:24 PM

Pour utiliser Bootstrap pour disposer d'un site Web, vous devez utiliser un système de grille pour diviser la page en conteneurs, lignes et colonnes. Ajoutez d'abord le conteneur, puis ajoutez les lignes dedans, ajoutez les colonnes dans la ligne et enfin ajoutez le contenu dans la colonne. La fonction de mise en page réactive de Bootstrap ajuste automatiquement la disposition en fonction des points d'arrêt (XS, SM, MD, LG, XL). Différentes dispositions sous différentes tailles d'écran peuvent être réalisées en utilisant des classes réactives.

Comment vérifier la date de bootstrap Comment vérifier la date de bootstrap Apr 07, 2025 pm 03:06 PM

Pour vérifier les dates dans Bootstrap, suivez ces étapes: introduisez les scripts et styles requis; initialiser le composant de sélecteur de date; Définissez l'attribut Data-BV-Date pour activer la vérification; Configurer les règles de vérification (telles que les formats de date, les messages d'erreur, etc.); Intégrez le cadre de vérification de bootstrap et vérifiez automatiquement l'entrée de date lorsque le formulaire est soumis.

See all articles