草庐IT

html - float :left; vs display:inline; vs display:inline-block; vs display:table-cell;

coder 2023-04-23 原文

我的问题

  1. 专业网页设计师是否喜欢这些方法?

  2. 网页浏览器在绘制网站时是否首选这些方法?

  3. 这只是个人喜好吗?

  4. 我还缺少其他技术吗?

注意:以上问题与设计多列布局有关


float :左;

http://jsfiddle.net/CDe6a/

这是我在创建列布局时经常使用的方法,它似乎工作得很好。父级确实会自行折叠,因此您只需要记住 clear:both; 之后。我刚刚发现的另一个缺点是无法垂直对齐文本。

显示:内联;

这似乎纠正了折叠父级的问题,但增加了空格。

http://jsfiddle.net/CDe6a/1/

从 html 中删除空格似乎是解决此问题的最简单方法,但如果您对 html 真的很挑剔,则不需要。

http://jsfiddle.net/CDe6a/2/

显示:内联 block ;

似乎行为与 display:inline; 完全一样。

http://jsfiddle.net/CDe6a/3/

显示:表格单元格;

http://jsfiddle.net/CDe6a/4/

完美运行。

我的想法:

我确定我错过了很多东西,比如某些会破坏布局的异常,但是 display:table-cell; 似乎效果最好,我想我会的开始替换 float:left;,因为我似乎总是搞砸 clear:both;。我在网上阅读了很多关于这方面的文章和博客,但没有一篇给出明确的答案,告诉我在布局我的网站时应该使用什么。

最佳答案

您询问的选项中:

  • float:left;
    我不喜欢 float ,因为需要有额外的标记来清除 float 。就我而言,整个 float 概念在 CSS 规范中设计得很糟糕。不过,我们现在对此无能为力。但重要的是它确实有效,并且适用于所有浏览器(甚至 IE6/7),所以如果您喜欢它,请使用它。

如果您使用 :after 选择器来清除 float ,则可能不需要额外的清除标记,但如果您想支持 IE6 或 IE7,这不是一个选项。

  • display:inline;
    这不应该用于布局,除了 IE6/7,其中 display:inline; zoom:1 是对 inline-block 的损坏支持的后备黑客。

  • display:inline-block;
    这是我最喜欢的选择。它在所有浏览器中都运行良好且始终如一,但需要注意的是 IE6/7,它支持某些元素。但是请参阅上面的 hacky 解决方案来解决这个问题。

inline-block 的另一个重要警告是,由于内联方面,元素之间的空白被视为与文本单词之间的空白相同,因此您可以在元素。有解决方法,但没有一个是理想的。 (最好的就是元素之间不要有任何空格)

  • display:table-cell;
    另一个您会遇到浏览器兼容性问题的问题。较旧的 IE 根本无法使用它。但即使对于其他浏览器,值得注意的是 table-cell 被设计用于在样式为 tabletable-行;单独使用 table-cell 不是预期的方法,因此您可能会遇到不同的浏览器对其进行不同的处理。

您可能错过的其他技巧?是的。

  • 既然你说这是多列布局,那么有一个CSS Columns feature你可能想知道的。但是,它不是最受支持的功能(即使在 IE9 中,IE 也不支持,并且所有其他浏览器都需要供应商前缀),因此您可能不想使用它。但这是另一种选择,你确实问过了。

  • 还有 CSS FlexBox 功能,旨在让您的文本在一个框之间流动。这是一个令人兴奋的功能,它允许一些复杂的布局,但这仍然在开发中——参见 http://html5please.com/#flexbox

希望对您有所帮助。

关于html - float :left; vs display:inline; vs display:inline-block; vs display:table-cell;,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11805352/

有关html - float :left; vs display:inline; vs display:inline-block; vs display:table-cell;的更多相关文章

  1. ruby - 使用 ruby​​ 将 HTML 转换为纯文本并维护结构/格式 - 2

    我想将html转换为纯文本。不过,我不想只删除标签,我想智能地保留尽可能多的格式。为插入换行符标签,检测段落并格式化它们等。输入非常简单,通常是格式良好的html(不是整个文档,只是一堆内容,通常没有anchor或图像)。我可以将几个正则表达式放在一起,让我达到80%,但我认为可能有一些现有的解决方案更智能。 最佳答案 首先,不要尝试为此使用正则表达式。很有可能你会想出一个脆弱/脆弱的解决方案,它会随着HTML的变化而崩溃,或者很难管理和维护。您可以使用Nokogiri快速解析HTML并提取文本:require'nokogiri'h

  2. ruby - RSpec - 使用测试替身作为 block 参数 - 2

    我有一些Ruby代码,如下所示:Something.createdo|x|x.foo=barend我想编写一个测试,它使用double代替block参数x,这样我就可以调用:x_double.should_receive(:foo).with("whatever").这可能吗? 最佳答案 specify'something'dox=doublex.should_receive(:foo=).with("whatever")Something.should_receive(:create).and_yield(x)#callthere

  3. ruby-on-rails - Rails HTML 请求渲染 JSON - 2

    在我的Controller中,我通过以下方式在我的index方法中支持HTML和JSON:respond_todo|format|format.htmlformat.json{renderjson:@user}end在浏览器中拉起它时,它会自然地以HTML呈现。但是,当我对/user资源进行内容类型为application/json的curl调用时(因为它是索引方法),我仍然将HTML作为响应。如何获取JSON作为响应?我还需要说明什么? 最佳答案 您应该将.json附加到请求的url,提供的格式在routes.rb的路径中定义。这

  4. ruby-on-rails - 使用 Sublime Text 3 突出显示 HTML 背景语法中的 ERB? - 2

    所以我在关注Railscast,我注意到在html.erb文件中,ruby代码有一个微弱的背景高亮效果,以区别于其他代码HTML文档。我知道Ryan使用TextMate。我正在使用SublimeText3。我怎样才能达到同样的效果?谢谢! 最佳答案 为SublimeText安装ERB包。假设您安装了SublimeText包管理器*,只需点击cmd+shift+P即可获得命令菜单,然后键入installpackage并选择PackageControl:InstallPackage获取包管理器菜单。在该菜单中,键入ERB并在看到包时选择

  5. ruby-on-rails - Enumerator.new 如何处理已通过的 block ? - 2

    我在理解Enumerator.new方法的工作原理时遇到了一些困难。假设文档中的示例:fib=Enumerator.newdo|y|a=b=1loopdoy[1,1,2,3,5,8,13,21,34,55]循环中断条件在哪里,它如何知道循环应该迭代多少次(因为它没有任何明确的中断条件并且看起来像无限循环)? 最佳答案 Enumerator使用Fibers在内部。您的示例等效于:require'fiber'fiber=Fiber.newdoa=b=1loopdoFiber.yieldaa,b=b,a+bendend10.times.m

  6. ruby-on-rails - Ruby url 到 html 链接转换 - 2

    我正在使用Rails构建一个简单的聊天应用程序。当用户输入url时,我希望将其输出为html链接(即“url”)。我想知道在Ruby中是否有任何库或众所周知的方法可以做到这一点。如果没有,我有一些不错的正则表达式示例代码可以使用... 最佳答案 查看auto_linkRails提供的辅助方法。这会将所有URL和电子邮件地址变成可点击的链接(htmlanchor标记)。这是文档中的代码示例。auto_link("Gotohttp://www.rubyonrails.organdsayhellotodavid@loudthinking.

  7. ruby-on-rails - Prawn PDF : I need to generate nested tables - 2

    我需要一个表,其中行实际上是2行表,一个嵌套表是..我怎样才能在Prawn中做到这一点?也许我需要延期..但哪一个? 最佳答案 现在支持子表:Prawn::Document.generate("subtable.pdf")do|pdf|subtable=pdf.make_table([["sub"],["table"]])pdf.table([[subtable,"original"]])end 关于ruby-on-rails-PrawnPDF:Ineedtogeneratenested

  8. ruby - 在匿名 block 中产生 - 2

    我没有理解以下行为(另请参阅inthisSOthread):defdef_testputs'def_test.in'yieldifblock_given?puts'def_test.out'enddef_testdoputs'def_testok'endblock_test=procdo|&block|puts'block_test.in'block.callifblockputs'block_test.out'endblock_test.calldoputs'block_test'endproc_test=procdoputs'proc_test.in'yieldifblock_gi

  9. ruby-on-rails - capybara ::ElementNotFound:无法找到 xpath "/html" - 2

    我正在学习http://ruby.railstutorial.org/chapters/static-pages上的RubyonRails教程并遇到以下错误StaticPagesHomepageshouldhavethecontent'SampleApp'Failure/Error:page.shouldhave_content('SampleApp')Capybara::ElementNotFound:Unabletofindxpath"/html"#(eval):2:in`text'#./spec/requests/static_pages_spec.rb:7:in`(root)'

  10. ruby - Ruby 中的单 block AES 解密 - 2

    我需要尝试一些AES片段。我有一些密文c和一个keyk。密文已使用AES-CBC加密,并在前面加上IV。不存在填充,纯文本的长度是16的倍数。所以我这样做:aes=OpenSSL::Cipher::Cipher.new("AES-128-CCB")aes.decryptaes.key=kaes.iv=c[0..15]aes.update(c[16..63])+aes.final它工作得很好。现在我需要手动执行CBC模式,所以我需要单个block的“普通”AES解密。我正在尝试这个:aes=OpenSSL::Cipher::Cipher.new("AES-128-ECB")aes.dec

随机推荐