- mongodb - 在 MongoDB mapreduce 中,如何展平值对象?
- javascript - 对象传播与 Object.assign
- html - 输入类型 ="submit"Vs 按钮标签它们可以互换吗?
- sql - 使用 MongoDB 而不是 MS SQL Server 的优缺点
专业网页设计师是否喜欢这些方法?
网页浏览器在绘制网站时是否首选这些方法?
这只是个人喜好吗?
我还缺少其他技术吗?
注意:以上问题与设计多列布局有关
这是我在创建列布局时经常使用的方法,它似乎工作得很好。父级确实会自行折叠,因此您只需要记住 clear:both;
之后。我刚刚发现的另一个缺点是无法垂直对齐文本。
这似乎纠正了折叠父级的问题,但增加了空格。
从 html 中删除空格似乎是解决此问题的最简单方法,但如果您对 html 真的很挑剔,则不需要。
似乎行为与 display:inline;
完全一样。
完美运行。
我确定我错过了很多东西,比如某些会破坏布局的异常,但是 display:table-cell;
似乎效果最好,我想我会的开始替换 float:left;
,因为我似乎总是搞砸 clear:both;
。我在网上阅读了很多关于这方面的文章和博客,但没有一篇给出明确的答案,告诉我在布局我的网站时应该使用什么。
最佳答案
您询问的选项中:
float:left;
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;
table-cell
被设计用于在样式为 table
和 table-行
;单独使用 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/
IE 似乎在来自未压缩的 raphaeljs 1.4.7 的以下第 2207 行(当然,在我的代码的上下文中): gs.left != (t = left + "px") && (gs.left =
这是在操纵 $("#mydiv").position().left 还是 $("#mydiv").offset().left? $("#mydiv").animate({"left":"-100"},
这个问题在这里已经有了答案: why left+(right-left)/2 will not overflow? (7 个答案) 关闭 1 年前。 在二分搜索 while 循环中: left, r
这个问题在这里已经有了答案: why left+(right-left)/2 will not overflow? (7 个答案) 关闭 1 年前。 在二分搜索 while 循环中: left, r
我有一个 Segment 类和一个这样的段数组: private static class Segment { int number, type; Segment(in
我有一个查询,它在子选择上执行 LEFT JOIN。此查询在高负载环境中运行,并在设定的要求内执行。查询(高度简化)如下所示: SELECT table_A.pKey , table_A.uKey
我在 SO 中看到一些创建 multilanguage websites in JavaScript 的好建议包括 this article on JavaScript internationaliz
我已经使用它年了,所以是时候全面了解它了。假设这样的查询: SELECT * FROM a LEFT JOIN b ON foo... LEFT JOIN c ON bar... document
我正在尝试对搜索框执行以下 MySql 查询。我试图返回“专辑”信息(标题等),同时包含该专辑中第一张图片的缩略图。但是,我必须查找两个表才能获取图像信息。首先,photos_albums包含该相册中
我有 2 个表,我想 LEFT JOIN 并过滤 LEFT 表上的结果。这些表是: -product_table,包含列 id 和 product_name -order_table,包含列 id、p
我理解 Left Join 应该做什么吗? 我有一个问题。将其称为查询 A。它返回 19 条记录。 我有另一个查询,查询 B。它返回 1,400 条记录。 我将查询 B 作为左连接插入到查询 A 中,
我正在使用 left: auto;希望重写left: 0;但它不起作用(请参阅 jsfiddle )-我想要 居中对齐。 HTML:
为什么这不起作用?我已经分配了一堆带有 float:left 的 div,并希望设置第一个元素的位置,然后用它更新所有 sibling 的位置。 例如,我将第一个元素的 css 设置为 left:50
这应该是非常基本的 CSS,但无论我尝试什么,该死的 div 就是不会去它应该去的地方! 这是 HTML: Registe-se Nome:
我在一个 div 中嵌套了一个 div。我正在尝试显示一些文本并且有效。然而,我想要的是文本居中对齐,即它有一个 left: -50%。但它什么都不做。但是当我执行类似 left: 20px 的操作时
我有一个包含跟踪数据的表格。在其他值中,该表具有列 traffic_medium、traffic_source 和 traffic_campaign。这些列有时确实包含 (none) 或 null 作
我正在尝试 中的代码。 在 GHC 版本 6.10.4 上: data ParseState = ParseState { string :: String } deriving (Show) n
我在使用用于显示自定义配置文件字段和任何(可选)对应值的 SQL 查询时遇到问题。 这是我正在使用的 SQL 查询: SELECT pf.`id`, pf.`name`, pv.`value` FRO
我目前制作了一个包含侧边栏和内容的容器,但是当我向侧边栏添加的文本多于向容器添加的文本时,第二个侧边栏会稍微 float 到一边。这些是我正在使用的代码。 HTML: Pl
这个问题在这里已经有了答案: Difference between margin and padding? (25 个答案) 关闭 5 年前。
我是一名优秀的程序员,十分优秀!