我已经编辑了 CodePen 示例,将一些内容添加到中心 div,所有容器 div 都有高度,但它显然不起作用,请看这里:
https://codepen.io/anon/pen/OEBxNr
这些行似乎导致了下面所说的差距:
.container {
...
-ms-grid-rows: 1fr 1fr 1fr;
}
.top {
...
height 8.4rem;
}
但我仍然遇到下面的第二个问题,可以在上面的 CodePen 中看到。
我有一个应用程序容器,其中顶部有导航,中间有页面,底部有页脚。我的布局在除 IE 和 Edge 之外的所有浏览器中都运行良好。
下面的代码在第二行和第一行之间创建了一个空隙。第二个问题是页面的大小远远超出了任何内容。
body, html {
height: 100%;
}
.container {
background:cyan;
display: grid;
grid-template-columns: repeat(12, 1fr);
grid-template-rows: minmax(auto, auto);
display: -ms-grid;
-ms-grid-columns: 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr;
-ms-grid-rows: 1fr 1fr 1fr;
height: 100%;
}
.top {
background: yellow;
height: 8.4rem;
position: relative;
z-index: 99;
grid-column: 1 / span 12;
grid-row: 1;
background: pink;
-ms-grid-column: 1;
-ms-grid-column-span: 12;
-ms-grid-row: 1;
}
.mid {
grid-column: 1 / span 12;
grid-row: 2;
min-width: 0;
background: yellow;
-ms-grid-column: 1;
-ms-grid-column-span: 12;
-ms-grid-row: 2;
height: 100%;
}
.bottom {
background: purple;
-ms-grid-column: 1;
-ms-grid-row: 3;
-ms-grid-column-span: 12;
}<body>
<div class='container'>
<div class='top'>TOP</div>
<div class='mid'>
<p>some long text some long text some long text some long text</p>
<p>some long text some long text some long text some long text</p>
<p>some long text some long text some long text some long text</p>
<p>some long text some long text some long text some long text</p>
<p>some long text some long text some long text some long text</p>
<p>some long text some long text some long text some long text</p>
<p>some long text some long text some long text some long text</p>
<p>some long text some long text some long text some long text</p>
<p>some long text some long text some long text some long text</p>
<p>some long text some long text some long text some long text</p>
<p>some long text some long text some long text some long text</p>
<p>some long text some long text some long text some long text</p>
<p>some long text some long text some long text some long text</p>
<p>some long text some long text some long text some long text</p>
<p>some long text some long text some long text some long text</p>
<p>some long text some long text some long text some long text</p>
<p>some long text some long text some long text some long text</p>
<p>some long text some long text some long text some long text</p>
<p>some long text some long text some long text some long text</p>
<p>some long text some long text some long text some long text</p>
</div>
<div class='bottom'>
<p>some short text</p>
</div>
</div>
</body>
最佳答案
代码目前的排列方式,所有支持 Grid 的 Microsoft 浏览器版本(这意味着遗留网格 IE10-11、遗留网格 Edge HTML12-15 和兼容网格 Edge HTML16 和 17)是接收以下遗留行声明:
-ms-grid-rows: 1fr 1fr 1fr;
请注意,Edge 的最新兼容版本可以理解标准和遗留 -ms 语法,因此重要的是不要将遗留语法放在最后。遗留声明必须在任何标准语法声明之前。
而兼容版本的 Firefox、Chrome 等都在接收:
grid-template-rows: minmax(auto, auto);
minmax() 函数将比具有一系列 1fr 行高更好地处理不相等的内容,这似乎会导致所述问题,因此需要为所有浏览器提供 minmax() 以进行行声明.请注意,所有那些 MS 旧版浏览器基本上都支持 minmax() ,前提是它有 -ms- 前缀。
编辑:正如 Michael_B 所建议的,使用 grid-template-rows: auto 而不是添加 minmax(auto, auto) 更简单。
.container {
background: cyan;
display: -ms-grid;
-ms-grid-columns: 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr;
-ms-grid-rows: auto;
/* legacy minmax() support */
display: grid;
grid-template-columns: repeat(12, 1fr);
grid-template-rows: auto;
}
.top {
background: pink;
-ms-grid-column: 1;
-ms-grid-column-span: 12;
-ms-grid-row: 1;
grid-column: 1 / span 12;
grid-row: 1;
height: 8.4rem;
}
.mid {
background: yellow;
-ms-grid-column: 1;
-ms-grid-column-span: 12;
-ms-grid-row: 2;
grid-column: 1 / span 12;
grid-row: 2;
}
.bottom {
background: purple;
-ms-grid-column: 1;
-ms-grid-column-span: 12;
-ms-grid-row: 3;
grid-column: 1 / span 12;
grid-row: 3;
}<div class='container'>
<div class='top'>TOP</div>
<div class='mid'>
<p>some long text some long text some long text some long text</p>
<p>some long text some long text some long text some long text</p>
<p>some long text some long text some long text some long text</p>
<p>some long text some long text some long text some long text</p>
<p>some long text some long text some long text some long text</p>
<p>some long text some long text some long text some long text</p>
<p>some long text some long text some long text some long text</p>
<p>some long text some long text some long text some long text</p>
<p>some long text some long text some long text some long text</p>
<p>some long text some long text some long text some long text</p>
<p>some long text some long text some long text some long text</p>
<p>some long text some long text some long text some long text</p>
<p>some long text some long text some long text some long text</p>
<p>some long text some long text some long text some long text</p>
<p>some long text some long text some long text some long text</p>
<p>some long text some long text some long text some long text</p>
<p>some long text some long text some long text some long text</p>
<p>some long text some long text some long text some long text</p>
<p>some long text some long text some long text some long text</p>
<p>some long text some long text some long text some long text</p>
</div>
<div class='bottom'>
<p>some short text</p>
</div>
</div>
.container 上的高度 100% 声明已被省略,因为这似乎会强制在大屏幕的 Edge 17 中的 .top 下出现一条小的水平背景青色 strip (但在大多数其他浏览器中不是,包括IE)。
为了方便起见,需要注意的另一件事是 repeat() 函数的操作在不同的 -ms- 遗留语法下受支持。所以你也可以替换以下内容:
-ms-grid-columns: 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr;
与
-ms-grid-columns: (1fr)[12];
有关网格语法的遗留 -ms 变体,请参见此处: https://msdn.microsoft.com/en-us/library/hh673533(v=vs.85).aspx
关于html - IE 和 Edge 中无法解释的网格行高,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50994972/
我在从html页面生成PDF时遇到问题。我正在使用PDFkit。在安装它的过程中,我注意到我需要wkhtmltopdf。所以我也安装了它。我做了PDFkit的文档所说的一切......现在我在尝试加载PDF时遇到了这个错误。这里是错误:commandfailed:"/usr/local/bin/wkhtmltopdf""--margin-right""0.75in""--page-size""Letter""--margin-top""0.75in""--margin-bottom""0.75in""--encoding""UTF-8""--margin-left""0.75in""-
我想将html转换为纯文本。不过,我不想只删除标签,我想智能地保留尽可能多的格式。为插入换行符标签,检测段落并格式化它们等。输入非常简单,通常是格式良好的html(不是整个文档,只是一堆内容,通常没有anchor或图像)。我可以将几个正则表达式放在一起,让我达到80%,但我认为可能有一些现有的解决方案更智能。 最佳答案 首先,不要尝试为此使用正则表达式。很有可能你会想出一个脆弱/脆弱的解决方案,它会随着HTML的变化而崩溃,或者很难管理和维护。您可以使用Nokogiri快速解析HTML并提取文本:require'nokogiri'h
我对最新版本的Rails有疑问。我创建了一个新应用程序(railsnewMyProject),但我没有脚本/生成,只有脚本/rails,当我输入ruby./script/railsgeneratepluginmy_plugin"Couldnotfindgeneratorplugin.".你知道如何生成插件模板吗?没有这个命令可以创建插件吗?PS:我正在使用Rails3.2.1和ruby1.8.7[universal-darwin11.0] 最佳答案 随着Rails3.2.0的发布,插件生成器已经被移除。查看变更日志here.现在
我尝试运行2.x应用程序。我使用rvm并为此应用程序设置其他版本的ruby:$rvmuseree-1.8.7-head我尝试运行服务器,然后出现很多错误:$script/serverNOTE:Gem.source_indexisdeprecated,useSpecification.Itwillberemovedonorafter2011-11-01.Gem.source_indexcalledfrom/Users/serg/rails_projects_terminal/work_proj/spohelp/config/../vendor/rails/railties/lib/r
我正在尝试在我的centos服务器上安装therubyracer,但遇到了麻烦。$geminstalltherubyracerBuildingnativeextensions.Thiscouldtakeawhile...ERROR:Errorinstallingtherubyracer:ERROR:Failedtobuildgemnativeextension./usr/local/rvm/rubies/ruby-1.9.3-p125/bin/rubyextconf.rbcheckingformain()in-lpthread...yescheckingforv8.h...no***e
我花了三天的时间用头撞墙,试图弄清楚为什么简单的“rake”不能通过我的规范文件。如果您遇到这种情况:任何文件夹路径中都不要有空格!。严重地。事实上,从现在开始,您命名的任何内容都没有空格。这是我的控制台输出:(在/Users/*****/Desktop/LearningRuby/learn_ruby)$rake/Users/*******/Desktop/LearningRuby/learn_ruby/00_hello/hello_spec.rb:116:in`require':cannotloadsuchfile--hello(LoadError) 最佳
在我的Controller中,我通过以下方式在我的index方法中支持HTML和JSON:respond_todo|format|format.htmlformat.json{renderjson:@user}end在浏览器中拉起它时,它会自然地以HTML呈现。但是,当我对/user资源进行内容类型为application/json的curl调用时(因为它是索引方法),我仍然将HTML作为响应。如何获取JSON作为响应?我还需要说明什么? 最佳答案 您应该将.json附加到请求的url,提供的格式在routes.rb的路径中定义。这
所以我在关注Railscast,我注意到在html.erb文件中,ruby代码有一个微弱的背景高亮效果,以区别于其他代码HTML文档。我知道Ryan使用TextMate。我正在使用SublimeText3。我怎样才能达到同样的效果?谢谢! 最佳答案 为SublimeText安装ERB包。假设您安装了SublimeText包管理器*,只需点击cmd+shift+P即可获得命令菜单,然后键入installpackage并选择PackageControl:InstallPackage获取包管理器菜单。在该菜单中,键入ERB并在看到包时选择
我在pry中定义了一个函数:to_s,但我无法调用它。这个方法去哪里了,怎么调用?pry(main)>defto_spry(main)*'hello'pry(main)*endpry(main)>to_s=>"main"我的ruby版本是2.1.2看了一些答案和搜索后,我认为我得到了正确的答案:这个方法用在什么地方?在irb或pry中定义方法时,会转到Object.instance_methods[1]pry(main)>defto_s[1]pry(main)*'hello'[1]pry(main)*end=>:to_s[2]pry(main)>defhello[2]pry(main)
我使用的是Firefox版本36.0.1和Selenium-Webdrivergem版本2.45.0。我能够创建Firefox实例,但无法使用脚本继续进行进一步的操作无法在60秒内获得稳定的Firefox连接(127.0.0.1:7055)错误。有人能帮帮我吗? 最佳答案 我遇到了同样的问题。降级到firefoxv33后一切正常。您可以找到旧版本here 关于ruby-无法在60秒内获得稳定的Firefox连接(127.0.0.1:7055),我们在StackOverflow上找到一个类