- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
网页:www.mathias-syversen.net
您好,这是我的第一篇文章,请多关照!我正在尝试使用@media 查询来检测屏幕尺寸和设备来制作一个移动友好的网页。
问题是,如果我的查询适用于移动设备,它也适用于桌面版本。可能是因为最大/最小宽度太大,以补偿具有高分辨率的新智能手机。
@media only screen and (min-device-width: 420px) and (max-device-width: 768px)仅适用于 iPad,但不适用于台式机或安卓手机。
尝试了无数种最大和最小屏幕宽度的组合,每次它在移动设备 (android) 上运行时也适用于桌面。
如果我尝试检测像素比,它适用于智能手机,但也适用于台式机(至少在 OS X 上,可能是因为它有视网膜显示屏)
我想要的是一种简单的方法来确定设备是否不是台式机,并应用适当的 css,无论它是 android、iOS、手机还是平板电脑。
@media screen and (max-width: 800px), (max-device-width: 480px), (max-device-width: 768px){}
现在适用于桌面 > 800px、平板电脑和手机。据我测试,这接缝解决了我的问题。
最佳答案
我应该指出我也在学习响应式,所以我可能不是 100% 正确。
视口(viewport)和像素分辨率(在移动设备上)不同。考虑在手机上加载一个标准的 960px 网页。你可以看到这一切,但如果你考虑到 iPhone 没有 960 像素的宽度(纵向);它的分辨率是 320(iPhone 3、3G、3GS)或 640(4 及以上)。 那么为什么您会看到整个页面?它会缩放或缩小页面以适合视口(viewport)。在 iPhone 上,它的默认宽度是 980px ,因此为什么基于 960px 网格系统的页面看起来很好,你不需要水平滚动,你甚至有 10px 的两边边距。
因此,默认视口(viewport)宽度大小为 980 像素,但原始分辨率宽度为 320 像素或 640 像素,具体取决于手机型号。为了进一步增加复杂性,所有 iPhone 都使用相同的 320 像素视口(viewport)宽度。当页面加载且不适合移动设备时,您实际上正在查看 3 倍缩小 (980/320)。
请注意,默认情况下,移动设备会横向扩展到最大 - 您无法再进行扩展或缩小。使用 iPhone 示例,您不能缩小超过 980 像素。如果页面超出 980 像素,您需要水平滚动页面。
如果您正在查看默认大小 (980px) 的页面,然后放大该页面的一部分(您可以放大到 100%),您只会看到该页面的一部分页面。
考虑到移动设备,除非您正在查看的网页在标题部分包含下面的元标记,否则它将缩放/缩小其默认视口(viewport)大小。
<meta name="viewport" content="width=device-width, initial-scale=1.0">
这告诉浏览器它的窗口宽度应该等于设备的 native 视口(viewport)宽度(注意,这不一定与 native 分辨率宽度相同)并且它应该缩放为 1 , 或 100%.
我建议你看看Viewport Sizes引用您要定位的设备。
根据该网站,Galaxy S4 的视口(viewport)尺寸为 360 x 640。
概念验证
创建一个div,设置2种样式:
在 S4 上以纵向和横向查看页面。 div 应该改变颜色;纵向应该是红色,横向应该是蓝色。
确保在文档的头部包含上面的 meta 标记。
根据我所做的研究,在设备上找到 native 视口(viewport)大小要容易得多 - 即当您以 1/100% 的比例查看浏览器窗口时。查找设备上的默认视口(viewport)大小比较困难,但值得庆幸的是,当您针对移动设备进行设计时,您最关心的是 native 视口(viewport)大小。
关于html - 针对移动应用到桌面的 CSS 媒体查询,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23086430/
似乎最近我看到越来越多的人开始在他们的样式表中使用 media="all" 而不是 media="screen"。 我的问题是什么时候应该使用 media="all" 而不是 media="scree
我正在尝试使用 https://www.instagram.com/developer/endpoints/media/ ,但对于我使用的每个媒体 ID,我总是得到相同的结果: { "meta
哟,我正在为服务器制作一个 MOTD 供最终用户阅读。但是,对于使用较小显示器的用户来说,它看起来非常压缩,例如,当分辨率为 1280x1040 时,它会被拉低。我不熟悉 CSS 中的 @media
我在我的 CSS 文件中使用了 @media screen 而不是 (-webkit-min-device-pixel-ratio:0)。我的问题是关于指定的值,即在这种情况下为“0”。值的变化将如何
我正在播放 Activity 中的视频,我需要显示/隐藏顶部栏 View 以及媒体 Controller 。所以当媒体 Controller 在屏幕上时,我的顶部 View 应该是可见的,当媒体 Co
我在我的 WordPress 主题中创建了一个小部件来显示图像。到目前为止,小部件可以工作,我可以输入值并在前端显示这些值。 当我选择一个小部件并将其放入小部件区域时,媒体上传按钮不起作用。在 Wor
我正在使用MWFeedParser从此处读取Youtube原子供稿:here xml代码: 我如何获取媒体的网址:缩略图? 我试图更改MWFeedParser.m 由此: else if ([cu
当使用 Python 向 Instagram API 发出 GET 请求时,传递所需的变量,如下所示 photos = api.media_search(lat=latitude, lng=longi
我正在使用与媒体播放器关联的媒体 Controller 来播放声音。问题是媒体 Controller 一旦失去焦点就会隐藏起来。我有一个按钮,按下时会播放声音,媒体 Controller 会出现在屏幕
我有一个媒体播放器并与它关联了一个媒体 Controller 。控件工作正常。 我遇到了两个问题: 当媒体 Controller 获得焦点时,即用户触摸它然后触摸屏幕的另一部分时,媒体 Control
关闭。这个问题需要debugging details .它目前不接受答案。 编辑问题以包含 desired behavior, a specific problem or error, and th
我在对话框中显示一个 VideoView 并向其附加一个媒体控件。 但是当我尝试点击媒体控件(播放、搜索栏等)时,对话框会消失。 媒体控制按钮不会被点击,而是将点击注册为 Dialog 的 Outsi
我目前正在使用 HTML 编写可打印文档,它将显示从数据库中提取的数据。我的想法是我将使用 HTML/CSS 使文档看起来不错,但它将专门用于打印。 文档的布局使用表格来控制数据库中数据的显示方式。
我需要在网络应用程序中打印我的报告。 我有在我的代码中。但它不应用任何样式。另一方面,如果我使用 在文档中编写 print.css 代码一切正常。 怎么了? 最佳答案 也许你在主样式之前插入打印样式
CSS html{ overflow-y:scroll; } js function showW(){ var a=($(window).width()); $('#
我编写了一个 Chrome 扩展程序,其中一个功能是您可以在您所在的页面中调出一个帮助面板,其中包含其使用指南。这个帮助面板是通过JS插入到页面中的,它的CSS都是通过$('#selector_for
我需要为 WORM 媒体开发归档软件。 这种类型的媒体允许通常的访问操作:读取、写入,但文件一旦写入,就无法修改或删除。 因为这样的媒体可能很昂贵,我想知道如何在开发阶段为测试创建一个假的 WORM
下面的这个 Activity 工作正常,但 mediaController 仅在我单击屏幕时显示。第二个问题是媒体 Controller 只显示 3 秒。我应该怎么做才能消除这个问题? public
我正在使用 VideoView 播放本地 mp4,我也在使用 MediaController。媒体控制栏未显示在我的视频剪辑下方,而是显示在屏幕中间。我使用 setAnchorView 将其附加到我的
我的布局包含 videoView 还有java代码中的Medicontrolleri: final MediaController mediaCont
我是一名优秀的程序员,十分优秀!