我正在编写一个类似于您在 iPhone 应用程序商店中获得的横向滚动文本阅读器小部件,其中应用程序的屏幕截图面板是嵌入在主垂直滚动面板中的不同的水平滚动面板。
在所有版本(包括全分辨率键盘/鼠标计算机样式)中,面板占据容器宽度的 100%,因此它就像横跨页面的水平条纹。
在小分辨率触摸界面版本中,即对于智能手机,我希望它也调整大小为窗口的整个高度,以便当您垂直滚动到它时,它可以占据整个屏幕。
iPhone 使这变得棘手,因为 $(window).height() 或您想要查询它的方式似乎取决于 URL 栏是否可见。
如果不对代码进行特殊封装以了解它是否在 iPhone 上,或者添加 hack 来滚动窗口以关闭 URL 栏然后查询高度,有没有办法询问 Safari 移动版,“窗口是什么height"在我的 3GS 上,无论 URL 栏当前是否可见,都会产生 416 的答案?
我想找到一种平台中立的方式来询问,对于所有主要的智能手机,“我可以将这个面板设置到什么高度,以便当你滚动到它时,它会填满整个浏览器窗口?”
谢谢,我已经为此苦苦思索了一段时间,已经在这里四处寻找,但找不到这个具体信息。
最佳答案
我也在寻找解决方案。没有成功。我最终遇到了你真正想避免的黑客攻击。但由于周围似乎没有其他解决方案,我想我将详细信息留在这里:
在我的例子中,页面只包含一个图层和一个图像,该图像应该与视口(viewport)允许的一样大,并保持原始纵横比。所以我有一个调用加载和方向更改的函数,它是这样的:
function updateImgLayer() {
$('#imgLayer img').hide(); // to prevent flickering
$('#imgLayer').height("5000px"); // to be sure it's bigger then the viewport
// timeout of zero ms makes sure layer-resize is finished in mobile-safari
// the android-browser seems to need more time – set it to 300 ms there.
setTimeout(function() {
window.scrollTo(0, 1); // scroll the url-bar out
$('#imgLayer').height(window.innerHeight + "px");
var imgH = $('#imgLayer .height').text(); // wrote img-dimensions in there by php
// the rest is to scale the image
var imgW = $('#imgLayer .width').text();
var winH = window.innerHeight;
var winW = $(window).width();
if((imgH/imgW) > (winH/winW)) {
$('#imgLayer img').css({ top: "0px", width: "auto", height: $('#imgLayer').height() + "px" });
} else {
$('#imgLayer img').width($('#imgLayer').width() + "px");
var cImgH = ($('#imgLayer').width()/imgW) * imgH;
var top = $('#imgLayer').height()/2 - cImgH/2;
$('#imgLayer img').css({ top: top+"px", height: "auto" });
}
$('#imgLayer img').fadeIn(200);
}, (android?300:0) );
关于javascript - 我可以以平台中立的方式查询无 URL 栏移动 Safari 窗口高度吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7872609/
类classAprivatedeffooputs:fooendpublicdefbarputs:barendprivatedefzimputs:zimendprotecteddefdibputs:dibendendA的实例a=A.new测试a.foorescueputs:faila.barrescueputs:faila.zimrescueputs:faila.dibrescueputs:faila.gazrescueputs:fail测试输出failbarfailfailfail.发送测试[:foo,:bar,:zim,:dib,:gaz].each{|m|a.send(m)resc
我正在用Ruby编写一个简单的程序来检查域列表是否被占用。基本上它循环遍历列表,并使用以下函数进行检查。require'rubygems'require'whois'defcheck_domain(domain)c=Whois::Client.newc.query("google.com").available?end程序不断出错(即使我在google.com中进行硬编码),并打印以下消息。鉴于该程序非常简单,我已经没有什么想法了-有什么建议吗?/Library/Ruby/Gems/1.8/gems/whois-2.0.2/lib/whois/server/adapters/base.
我试图获取一个长度在1到10之间的字符串,并输出将字符串分解为大小为1、2或3的连续子字符串的所有可能方式。例如:输入:123456将整数分割成单个字符,然后继续查找组合。该代码将返回以下所有数组。[1,2,3,4,5,6][12,3,4,5,6][1,23,4,5,6][1,2,34,5,6][1,2,3,45,6][1,2,3,4,56][12,34,5,6][12,3,45,6][12,3,4,56][1,23,45,6][1,2,34,56][1,23,4,56][12,34,56][123,4,5,6][1,234,5,6][1,2,345,6][1,2,3,456][123
我主要使用Ruby来执行此操作,但到目前为止我的攻击计划如下:使用gemsrdf、rdf-rdfa和rdf-microdata或mida来解析给定任何URI的数据。我认为最好映射到像schema.org这样的统一模式,例如使用这个yaml文件,它试图描述数据词汇表和opengraph到schema.org之间的转换:#SchemaXtoschema.orgconversion#data-vocabularyDV:name:namestreet-address:streetAddressregion:addressRegionlocality:addressLocalityphoto:i
使用带有Rails插件的vim,您可以创建一个迁移文件,然后一次性打开该文件吗?textmate也可以这样吗? 最佳答案 你可以使用rails.vim然后做类似的事情::Rgeneratemigratonadd_foo_to_bar插件将打开迁移生成的文件,这正是您想要的。我不能代表textmate。 关于ruby-使用VimRails,您可以创建一个新的迁移文件并一次性打开它吗?,我们在StackOverflow上找到一个类似的问题: https://sta
查看Ruby的CSV库的文档,我非常确定这是可能且简单的。我只需要使用Ruby删除CSV文件的前三列,但我没有成功运行它。 最佳答案 csv_table=CSV.read(file_path_in,:headers=>true)csv_table.delete("header_name")csv_table.to_csv#=>ThenewCSVinstringformat检查CSV::Table文档:http://ruby-doc.org/stdlib-1.9.2/libdoc/csv/rdoc/CSV/Table.html
从给定URL下载文件并立即将其上传到AmazonS3的更直接的方法是什么(+将有关文件的一些信息保存到数据库中,例如名称、大小等)?现在,我既不使用Paperclip,也不使用Carrierwave。谢谢 最佳答案 简单明了:require'open-uri'require's3'amazon=S3::Service.new(access_key_id:'KEY',secret_access_key:'KEY')bucket=amazon.buckets.find('image_storage')url='http://www.ex
我正在编写一个小脚本来定位aws存储桶中的特定文件,并创建一个临时验证的url以发送给同事。(理想情况下,这将创建类似于在控制台上右键单击存储桶中的文件并复制链接地址的结果)。我研究过回形针,它似乎不符合这个标准,但我可能只是不知道它的全部功能。我尝试了以下方法:defauthenticated_url(file_name,bucket)AWS::S3::S3Object.url_for(file_name,bucket,:secure=>true,:expires=>20*60)end产生这种类型的结果:...-1.amazonaws.com/file_path/file.zip.A
我发现ActiveRecord::Base.transaction在复杂方法中非常有效。我想知道是否可以在如下事务中从AWSS3上传/删除文件:S3Object.transactiondo#writeintofiles#raiseanexceptionend引发异常后,每个操作都应在S3上回滚。S3Object这可能吗?? 最佳答案 虽然S3API具有批量删除功能,但它不支持事务,因为每个删除操作都可以独立于其他操作成功/失败。该API不提供任何批量上传功能(通过PUT或POST),因此每个上传操作都是通过一个独立的API调用完成的
我知道我可以指定某些字段来使用pluck查询数据库。ids=Item.where('due_at但是我想知道,是否有一种方法可以指定我想避免从数据库查询的某些字段。某种反拔?posts=Post.where(published:true).do_not_lookup(:enormous_field) 最佳答案 Model#attribute_names应该返回列/属性数组。您可以排除其中一些并传递给pluck或select方法。像这样:posts=Post.where(published:true).select(Post.attr