- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我的问题主要是关于页面重新加载而不是视网膜检测。我在视网膜显示的 head 标签中使用下面的代码:
<script type="text/javascript">
if( document.cookie.indexOf('device_pixel_ratio') == -1
&& 'devicePixelRatio' in window
&& window.devicePixelRatio == 2 ){
var date = new Date();
date.setTime( date.getTime() + 3600000000 );
document.cookie = 'device_pixel_ratio=' + window.devicePixelRatio;
//if cookies are not blocked, reload the page
if(document.cookie.indexOf('device_pixel_ratio') != -1) {
window.location.reload(true);
}
}
</script>
它检测访问者的屏幕类型,然后存储 cookie,如果是视网膜显示屏则重新加载。它的工作没有问题,除了一个。
重新加载函数不会停止页面渲染。因此,您在第一次访问时看到无样式的页面(加载一半)然后刷新。之后,由于存储了 cookie,站点的其余部分一切正常。
很明显,PHP 没有提供检测屏幕类型的功能。必须通过JS来完成。但是 JS 没有合适的工具来重新加载/重定向而不加载页面,甚至在 head 中使用代码。
简而言之,我介于两者之间。我希望有人可能会建议重新加载而不在第一次加载时显示任何内容(它甚至显示我放入头部的内联样式)。或者在第一次加载时显示标准图像并允许 Retina 浏览其余的浏览体验是最好的选择?
顺便说一下,我同时尝试了 reload(true) 和 reload(false)。它没有帮助。
更新:请参阅下面 Marat Tanalin 的回答,了解可能的解决方法和更好的视网膜/高清显示图像使用而不是存储 cookie + 重新加载的解决方案。
在深入研究之后,我意识到由于 * 缓存方法,生成视网膜图像和标准图像可能并不是所有时间的答案。换句话说,在第一次访问时向访问者显示低质量图像并在刷新后显示高质量图像可能不起作用,因为低质量图像(和脚本)已经缓存。
我决定使用支持 SVG 上传的 1.5 倍单个图像大小。虽然它不是每个方面的 100% 最佳答案,但比失去可靠性更好的选择。
*我是一名 Wordpress 开发人员,我引用了 WP Super Cache 和类似的缓存方法,但请注意它也可能是其他缓存方法的问题。
最佳答案
本质上,您希望在运行此脚本之前停止呈现页面。
这可以使用外部 JS 文件来完成。当浏览器找到一个外部文件时,它会等到它运行。另一方面,如果你有一个内联 <script>
标记,则浏览器不会等待。
实际上,建议永远不要阻止页面呈现,以缩短页面加载时间,但出于此目的,这是必要的。更多信息可以咨询https://developers.google.com/speed/docs/insights/BlockingJS
关于重新加载期间的 Javascript Retina/HD 显示检测和阻止页面呈现,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30949276/
我没有 Retina 设备,但我一直在网上看到这个讨论。我已阅读有关为配备 Retina 显示屏的设备提供 2 倍图像尺寸的解决方案,以确保位图不会变得模糊。 但是,我不明白这是如何工作的。首先,正如
根据我的研究,我了解到您想将图像的大小加倍以使其在视网膜显示器上看起来更清晰。 对于尺寸为500X500 px的图片,我想将它们存储为1000X1000。 如有错误请指正 现在的问题是,通过使用 Go
目前,我的应用程序中的所有 UIImageView 都设置为 scaleToFill 模式,仅使用一个视网膜图像而不设置任何非视网膜图像。我想在非视网膜显示器上,额外的分辨率将自行丢失。 问题:这种方
我有以下媒体查询,以选择 iPad 视网膜和更小的显示器。 @media only screen and (min-device-width : 768px) and (max-device-widt
在深入研究我的下一个项目之前,我正在寻求建议。我想支持 iOS 现在支持的所有各种分辨率(视网膜、非视网膜 iPhone 和所有 3 款 iPad)。 开发人员完成这项工作最常用的方法是什么?我看到过
有没有一种方法可以在 Windows 上模拟 Retina 显示屏来测试 HiDPI 显示屏(例如 Retina)的网站? 我在标准的 24"1920x1080 显示器上运行 Windows。昨晚我在
我遇到了麻烦。我正在使用带有 UIKit 的 cocos2d。 Cocos2d版本为1.0.1。 我已经按照文档中的建议将平铺 map 添加到项目中: http://www.cocos2d-iphon
有人可以告诉我 iPhone/iPad 和 iPhone(Retina)/iPad(Retina) 的理想图像分辨率是多少吗?我从苹果网站和维基百科上获取了这些测量值。见下文: 普通 iPhone 4
这是我第一次开发应用程序。 根据 Apple iOS 人机界面指南,UIBarButtonItem 图像尺寸约为 20 x 20 和约 40 x 40。 我知道20x20是针对iPhone4之前版本的
我正在使用 Assets 目录来管理我应用程序的所有图像,并且我“正常”加载这些图像 [UIImage imageNamed:@"my-image"]; 我想做的是从 Assets 目录加载图像的非视
这可能是一个小众问题,实际上更像是一个小问题,但是: 我可以让 Xcode 自动构建到 iPhone Retina 模拟器和 iPad 非 Retina 模拟器吗? 即使使用 27"iMac,Reti
我有一个问题可能听起来很奇怪,但作为一个新手,我猜 no question 是一个愚蠢的问题...... 我是否需要为所有四台设备使用单独的 Storyboard? 现在我有两个 Storyboard
我是 opengl es 2.0 开发的新手。我从屏幕截图中获得的 UIImage 在非视网膜设备(iphone 4 和 ipad)上看起来不错,但是当我从视网膜设备上获得屏幕截图时,它似乎放大了。这
我正在使用 XCode 4.5 版。对于每个 Xib,我可以选择大小为“Retina 3.5 全屏”或“Retina 4 全屏”。 我的疑问是:如果我选择 Retina 4 全屏,我的应用程序能否在旧
我正在使用最新的 xCode 5,我正在尝试为我的通用应用程序设置启动图像。当我选择 Launch images for iPhone 时,一切正常。但是现在,当我尝试为 iPad 选择启动图像时,x
今天,我更新了Xcode4.5,并在我的电脑上安装了Xcode4.3,安装后我打开Xcode4.5,当我想运行我的应用程序时,只有IOS Device,iPad 6.0模拟器和 iPhone 6.0
我正在使用模拟器为 iPhone 5 准备我的应用程序,我发现了一个奇怪的问题,在我的一个 View 中,我的几个按钮在 iPhone(Retina 4 英寸) 模拟器,但在 iPhone(Retin
我们的目标是模拟开发人员可以使用原生 iOS 应用执行的操作:即,使用基于单位的单一布局来适应 Retina 显示屏 (640x960) 和非 Retina 显示屏 (320x480)。 所有 iOS
这是我第一次提问,因为我是新来的。非常感谢您的回答!感谢您抽出时间。 使用Xcode 5.1.1 这是我的问题,在模拟器或实际设备上测试时,结果不同。请参阅食物图像上所附的屏幕截图。当我在模拟器iPh
我更新了一个旧应用程序,修复了一个小错误。该应用程序是使用 Xcode 5.1 编译的。(无法使用 Assets 目录或添加 iPhone 6 和 6 Plus 图像。)但是,当我尝试提交它进行审核时
我是一名优秀的程序员,十分优秀!