”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > 全新的显示属性。

全新的显示属性。

发布于2024-07-31
浏览:121

The All-New display Property.

从 Chrome 115 开始,CSS 显示属性有多个值。 display: flex 变为 display: block flex,display: block 变为 display: block flow。您知道的单个值现在被视为遗留值,但保留在浏览器中以实现向后兼容性。

为什么迟到这么久?

简而言之:它改变了我们解释盒子模型等事物的方式。该规范仍然是 CR 快照,这意味着 W3C 会从实施者那里收集经验来最终确定该标准。因此,其中一些可能仍会发生变化。

重做将显示类型分为两部分:外显示类型和内显示类型。

外部显示类型决定主框本身如何参与流布局。

内部显示类型决定了其后代框的布局方式(替换元素除外,这有点复杂)。

因此 display: flex 变成了 display: block flex 意味着外部显示类型是块(它在外部表现为块元素),但其子元素根据 flex 布局进行渲染。

这与以前的行为相同,但是通过此更改,我们可以讨论 display 属性对子元素和周围元素的影响。在我看来,这种心理模型可以更轻松地创建更可预测的布局,并且更容易解释不同的布局模式及其效果。

在较新的课程或教程中,对盒子模型的良好解释不仅需要涵盖边距、边框、填充、宽度和高度,还需要涵盖盒子大小和显示属性。

显示属性的有效值是什么?

正如已经提到的,一些旧财产现在已经成为遗产。以下是所有有效属性:

对于多值语法显示:outer-type inside-type 有效的外部类型为blockinlinerun-in。有效的内部显示类型为 flowflow-roottableflexgrid红宝石

还有有效的单值:list-itemcontentsnone

最重要的是,CSS 有一些仍然有效的内部显示值。使用表格或 ruby​​ 显示类型时将计算这些值。

以下组合现已成为旧版:inline-blockinline-tableinline-flexinline-grid 。它们可以替换为多值等价物,例如:display: inline flex.

现代浏览器的最新版本支持多值:https://caniuse.com/mdn-css_properties_display_multi-keyword_values

Caniuse 用于显示属性的多关键字值。

就这样了,伙计们!

非常感谢您的阅读!

版本声明 本文转载于:https://dev.to/manojgohel/the-all-new-display-property-3572?1如有侵犯,请联系[email protected]删除
最新教程 更多>
  • 如何使用PHP从XML文件中有效地检索属性值?
    如何使用PHP从XML文件中有效地检索属性值?
    从php 您的目标可能是检索“ varnum”属性值,其中提取数据的传统方法可能会使您感到困惑。 - > attributes()为$ attributeName => $ attributeValue){ echo $ attributeName,'=“',$ at...
    编程 发布于2025-02-06
  • 如何从Python中的字符串中删除表情符号:固定常见错误的初学者指南?
    如何从Python中的字符串中删除表情符号:固定常见错误的初学者指南?
    从python 导入编解码器 导入 text = codecs.decode('这狗\ u0001f602'.encode('utf-8'),'utf-8') 印刷(文字)#带有表情符号 emoji_pattern = re.compile(“ [”...
    编程 发布于2025-02-06
  • 在映射到MySQL枚举列时,如何确保冬眠保留值?
    在映射到MySQL枚举列时,如何确保冬眠保留值?
    在hibernate中保存枚举值:故障排除错误的列type ,他们各自的映射至关重要。在Java中使用枚举类型时,至关重要的是,建立冬眠的方式如何映射到基础数据库。在您的情况下,您已将MySQL列定义为枚举,并在Java中创建了相应的枚举代码。但是,您遇到以下错误:“ MyApp中的错误列类型。...
    编程 发布于2025-02-06
  • 如何使用char_length()在mySQL中按字符串长度对数据进行排序?
    如何使用char_length()在mySQL中按字符串长度对数据进行排序?
    [2使用内置的char_length()function。 char_length()和length() 此查询将从指定的表中检索所有行,并基于上升顺序对它们进行排序指定列的字符长度。带有更长字符串的行将出现在结果的底部。
    编程 发布于2025-02-06
  • 如何使用代理身份验证创建GO HTTP客户端?
    如何使用代理身份验证创建GO HTTP客户端?
    在使用Authentication 时,使用authentication时要求。当将代理支持集成到现有的第三方代码中时,这可能会构成挑战。在这种情况下,另一种方法是使用所需的代理配置创建自定义的HTTP客户端。然后,可以在第三方软件包中使用此客户端来代替默认的HTTP客户端。以下是如何使用http...
    编程 发布于2025-02-06
  • 如何使用Python的记录模块实现自定义处理?
    如何使用Python的记录模块实现自定义处理?
    使用Python的Loggging Module 确保正确处理和登录对于疑虑和维护的稳定性至关重要Python应用程序。尽管手动捕获和记录异常是一种可行的方法,但它可能乏味且容易出错。解决此问题,Python允许您覆盖默认的异常处理机制,并将其重定向为登录模块。这提供了一种方便而系统的方法来捕获和...
    编程 发布于2025-02-06
  • 如何在没有404个错误的情况下使用泽西2.0提供静态资源(例如index.html)?
    如何在没有404个错误的情况下使用泽西2.0提供静态资源(例如index.html)?
    在泽西岛估算静态资源的404错误映射拦截所有传入的请求,没有留出空间的网络容器来提供静态内容。为了解决此问题,我们深入探究了过滤器的领域,尤其是com.sun.jersey.spi.container.servlet.servlet.servlet.servletcontainer for Jer...
    编程 发布于2025-02-06
  • 如何干净地删除匿名JavaScript事件处理程序?
    如何干净地删除匿名JavaScript事件处理程序?
    在这里工作/},false); 不幸的是,答案是否。除非在Creation中存储对处理程序的引用。要解决此问题,请考虑将事件处理程序存储在中心位置,例如页面的主要对象,请考虑将事件处理程序存储在中心位置,否则无法清理匿名事件处理程序。 。这允许在需要时轻松迭代和清洁处理程序。
    编程 发布于2025-02-06
  • 我可以将加密从McRypt迁移到OpenSSL,并使用OpenSSL迁移MCRYPT加密数据?
    我可以将加密从McRypt迁移到OpenSSL,并使用OpenSSL迁移MCRYPT加密数据?
    将我的加密库从mcrypt升级到openssl 问题:是否可以将我的加密库从McRypt升级到OpenSSL?如果是这样?使用openssl?答案:可以使用mcrypt数据加密数据,可以使用openssl。关于如何使用openssl对McRypt进行加密的数据: openssl_decrypt...
    编程 发布于2025-02-06
  • 如何使用FormData()处理多个文件上传?
    如何使用FormData()处理多个文件上传?
    )处理多个文件输入时,通常需要处理多个文件上传时,通常是必要的。可以将fd.append("fileToUpload[]", files[x]);方法用于此目的,允许您在单个请求中发送多个文件。 初始尝试 在JavaScript中,一种常见方法是:); 但是,此代码仅处理第一...
    编程 发布于2025-02-06
  • HTML格式标签
    HTML格式标签
    HTML 格式化元素 **HTML Formatting is a process of formatting text for better look and feel. HTML provides us ability to format text without us...
    编程 发布于2025-02-06
  • 您什么时候应该使用_mm_sfence,_mm_lfence和_mm_mfence?
    您什么时候应该使用_mm_sfence,_mm_lfence和_mm_mfence?
    Memory Ordering in x86x86 CPUs have a strongly有序的内存模型,但是C和C的模型较弱。因此,需要其他预防措施以确保正确的内存排序并防止数据损坏或种族条件。 _ mm_sfence _ mm_lfence Summary在NT存储之后使用_mm_sfe...
    编程 发布于2025-02-06
  • 大批
    大批
    [2 数组是对象,因此它们在JS中也具有方法。 切片(开始):在新数组中提取部分数组,而无需突变原始数组。 令arr = ['a','b','c','d','e']; // USECASE:提取直到索引作...
    编程 发布于2025-02-06
  • 如何使用替换指令在GO MOD中解析模块路径差异?
    如何使用替换指令在GO MOD中解析模块路径差异?
    克服go mod中的模块路径差异 coreos/bbolt:github.com/coreos/ [email受保护]:解析go.mod:模块将其路径声明为:go.etcd.io/bbolt `要解决此问题,您可以在go.mod文件中使用替换指令。只需在go.mod的末尾添加以下行:[&& &...
    编程 发布于2025-02-06
  • 如何使用newtonsoft的json.net将JSON列为C#对象列表?
    如何使用newtonsoft的json.net将JSON列为C#对象列表?
    [2 C#对象的列表,利用Newtonsoft的JSON.NET库,同时仅关注目标类中的特定属性。 1。将JSON转换为c#类结构:利用JSON2CSHARP.com的JSON转换器将JSON转换为C#类结构。 2。创建目标对象类:定义一个类似于预期对象结构的c#类。 3。值得注意的json字符串:...
    编程 发布于2025-02-06

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3