- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
随着 css var 的引入,我想知道 为什么 --
会被选为表示 var 的原因。
考虑到 CSS 具有半功能 calc
功能,我觉得 --
很容易与其他语言中的减量运算符混淆。
我很好奇是否有任何历史意义或技术限制导致选择 --
。当 CSS 标记通常是单个标记(#、.、@ 等)时,double 尤其让我感到困惑。此外,使用已被其他事物使用的符号也很有趣(尤其是当它对以 --
开头的类名有效时)。
示例:
@custom-media --lt-sm (width < 576px);
--grey300: #e0e0e0;
.navbarItem {
display: inline-block;
text-align: center;
border-top: 1px solid var(--grey300);
border-left: 1px solid var(--grey300);
@media (--lt-sm) {
flex-grow: 1;
}
&:last-child {
border-right: 1px solid var(--grey300);
}
}
免责声明
有些人可能会争论这个问题的有效性,但了解原因是记住特定概念的关键技巧。
我能找到的唯一相关讨论:
In the telcon today, we resolved to use a "--" prefix to indicate custom properties and other custom things.
We discussed whether the prefix is maintained or dropped when referring to the custom property from a var() function, but didn't actually resolve. Discussion in the call leaned toward dropping the prefix, like I do currently with var-* properties, but some side discussion with Simon and Sylvain argued for using the full name, as there are confusing cases like "--0" or "----".
So, while I understand the potential confusion caused by authors possibly thinking that var() can take any property name as an argument, I think it's overruled by the confusion over what needs to be escaped in various circumstances. Escaping rules are always very confusing to authors, so I'm going to go with "use the custom property name literally as the var() argument".
引用:
http://lists.w3.org/Archives/Public/www-style/2014Mar/0467.html
最佳答案
除了避免与其他答案中提到的以单个破折号开头的供应商前缀发生冲突外,请记住,CSS 标识的语法不允许除字母、数字、破折号和下划线以外的任何内容(请参阅section 4.1.3 的 CSS2)。如果自定义属性由任何其他符号表示,每个现有的 CSS 实现都需要更新甚至重写其解析器,以适应用于自定义属性名称的任何符号。1
来自minutes通过消息中提到的电话,您可以看到避免与以单个破折号开头的供应商前缀发生冲突的假设是正确的。 --
的使用确实需要对解析器进行较小的更改,因为 idents normally cannot start with double dashes (正如 klumme 指出的那样)。我不确定现有的实现是如何解析 (d) 声明的,但是可以安全地假设我的推理仍然成立:因为 idents 可以 以一个破折号开头,所以使用第一个破折号不会立即导致解析错误,因此解析器可以确定它是否正在查看 <property>
或 <custom-property-name>
(或者 然后 如果它不支持自定义 Prop 会遇到解析错误),然后再决定应该如何进行。
此更改也反射(reflect)在 css 变量规范中,在 section 2 中(我也介绍了 here ):
A custom property is any property whose name starts with two dashes (U+002D HYPHEN-MINUS), like
--foo
. The<custom-property-name>
production corresponds to this: it’s defined as any valid identifier that starts with two dashes.
所以使用破折号是因为它们适合现有的语法,只需要对解析器进行微小的更改,并且特别加倍以防止与供应商前缀冲突(请注意,破折号和下划线对于供应商前缀是可以互换的,因此单个下划线不会削减它要么)。
1 事实上,我给了this very same reasoning就在几周前回答别人的问题时,尽管他们的问题不是关于为自定义 Prop 名称选择的前缀。
关于css - CSS 中是否有任何技术限制导致决定将 `--` 用于 vars?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42622197/
我在为 MacOSX 构建的独立包中添加 DMG 背景的自定义图标时遇到问题。我在项目的根目录中添加了一个包。正在从中加载自定义图标,但没有加载 DMG 背景图标。我正在使用 Java fx 2.2.
Qt for Symbian 和 Qt for MeeGo 有什么区别?我知道 Qt 是一个交叉编译平台。这是否意味着如果我使用来自 Qt 的库,完全相同的库可以在所有支持 Qt 的设备(例如 Sym
我正在尝试使用 C# .NET 3.5/4.0 务实地运行 SQL Server 数据库的备份。我已经找到了如何完成此操作,但是我似乎找不到用于备份的命名空间库。 我正在寻找 Microsoft.Sq
我最近在疯狂学习 Java,但我通常是一名 .NET 开发人员。 (所以请原谅我的新手问题。) 在 .Net 中,我可以在不使用 IIS 的情况下开发 ASP.Net 页面,因为它有一个简化的 Web
这post仅当打印命令中有字符串时才有用。现在我有大量的源代码,其中包含一条声明,例如 print milk,butter 应该格式化为 print(milk,butter) 用\n 捕获行尾并不成功
所以我的问题是: https://gist.github.com/panSarin/4a221a0923927115584a 当我保存这个表格时,我收到了标题中的错误 NoMethodError (u
如何让 Html5 音频在点击时播放声音? (ogg 用于 Firefox 等浏览器,mp3 用于 chrome 等浏览器) 到目前为止,我可以通过 onclick 更改为单个文件类型,但我无法像在普
如果it1和it2有什么区别? std::set s; auto it1 = std::inserter(s, s.begin()); auto it2 = std::inserter(s, s.en
4.0.0 com.amkit myapp SpringMVCFirst
我目前使用 Eclipse 作为其他语言的 IDE,而且我习惯于不必离开 IDE 做任何事情 - 但是我真的很难为纯 ECMAScript-262 找到相同或类似的设置。 澄清一下,我不是在寻找 DO
我想将带有字符串数组的C# 结构发送到C++ 函数,该函数接受void * 作为c# 结构和char** 作为c# 结构字符串数组成员。 我能够将结构发送到 c++ 函数,但问题是,无法从 c++ 函
我正在使用动态创建的链接: 我想为f:param附加自定义转换器,以从#{name}等中删除空格。 但是f:param中没有转换器
是否可以利用Redis为.NET创建后写或直写式缓存?理想情况下,透明的高速缓存是由单个进程写入的,并且支持从数据库加载丢失的数据,并每隔一段时间持久保存脏块? 我已经搜查了好几个小时,也许是goog
我正在通过bash执行命令的ssh脚本。 FILENAMES=( "export_production_20200604.tgz" "export_production_log_2020060
我需要一个正则表达式来出现 0 到 7 个字母或 0 到 7 个数字。 例如:匹配:1234、asdbs 不匹配:123456789、absbsafsfsf、asf12 我尝试了([a-zA-Z]{0
我有一个用于会计期间的表格,该表格具有期间结束和开始的开始日期和结束日期。我使用此表来确定何时发生服务交易以及何时在查询中收集收入,例如... SELECT p.PeriodID, p.FiscalY
我很难为只接受字符或数字的 Laravel 构建正则表达式验证。它是这样的: 你好<-好的 123 <- 好的 你好123 <-不行 我现在的正则表达式是这样的:[A-Za-z]|[0-9]。 reg
您实际上会在 Repeater 上使用 OnItemDataBound 做什么? 最佳答案 “此事件为您提供在客户端显示数据项之前访问数据项的最后机会。引发此事件后,数据项将被清空,不再可用。” ~
我有一个 fragment 工作正常的项目,我正在使用 jeremyfeinstein 的 actionbarsherlock 和滑动菜单, 一切正常,但是当我想自定义左侧抽屉列表单元格时,出现异常
最近几天,我似乎平均分配时间在构建我的第一个应用程序和在这里发布问题!! 这是我的第一个应用程序,也是我们的设计师完成的第一个应用程序。我试图满足他所做的事情的外观和感觉,但我认为他没有做适当的事情。
我是一名优秀的程序员,十分优秀!