CSS中calc(100%-100px)为什么不加空格会不生效?

简介: 笔记

问题起因

今天再使用calc时发现无法生效,我的写法是:

 width: calc(100%-100px);

页面无效果,加空格后就发现有效果了:

width: calc(100% - 100px);

有亿点疑惑,这是为什么?

calc是什么?

css3的 计算属性,用于动态计算长度值。calc语法:

calc(expression)//expression是数学表达式

用法&定义

  • 运算符前后都需要保留一个空格,例如:width: calc(100% - 100px)
  • 任何长度值都可以使用calc()函数进行计算;
  • calc()函数支持 "+", "-", "*", "/" 运算;
  • calc()函数使用标准的数学运算优先级规则;

先了解一下CSS中基础语法和数据类型:

文档链接》》

在文档的这里应该是这里的核心语法:40.png

stylesheet  : [ CDO | CDC | S | statement ]*;
statement   : ruleset | at-rule;
at-rule     : ATKEYWORD S* any* [ block | ';' S* ];
block       : '{' S* [ any | block | ATKEYWORD S* | ';' S* ]* '}' S*;
ruleset     : selector? '{' S* declaration? [ ';' S* declaration? ]* '}' S*;
selector    : any+;
declaration : property S* ':' S* value;
property    : IDENT;
value       : [ any | block | ATKEYWORD S* ]+;
any         : [ IDENT | NUMBER | PERCENTAGE | DIMENSION | STRING
              | DELIM | URI | HASH | UNICODE-RANGE | INCLUDES
              | DASHMATCH | ':' | FUNCTION S* [any|unused]* ')'
              | '(' S* [any|unused]* ')' | '[' S* [any|unused]* ']'
              ] S*;
unused      : block | ATKEYWORD S* | ';' S* | CDO S* | CDC S*;

DIMENSION语法在最上面:

DIMENSION    {num}{ident}

num应该是数字,翻一下ident的定义:

在4.1.1第二段的开头

41.png

ident    [-]?{nmstart}{nmchar}*

nmstart和nmchar的分别有:

nmstart [_a-z]|{nonascii}|{escape}
nmchar [_a-z0-9-]|{nonascii}|{escape}

所以在编译calc(100%-100px)时会产生歧义,在解析器看来应该是:100 和 %-100px,会将%-100px认为是单位,但是无该单位的定义,所以这段就无法解析。所以使用空格隔开。但是感觉这个是可以理解的,因为在数学标识符当中还有正号和负号这两个元素。如果纯单位方式来判断的话,理应calc(100%+100px)、calc(100% +100px)或者calc(100% -100px)也生效,但是实际无法生效。为什么非得要都用空格?所以感觉这里需要引用正负号这个概念。就像margin和padding中会常常用到负数。就像用calc(100% -100px)为例,将其解析为100%和-100px,使用什么运算符号进行运算?

目录
相关文章
|
8月前
|
编解码 前端开发 UED
解密CSS单位:px、em、vh的区别与应用
解密CSS单位:px、em、vh的区别与应用
155 0
|
8月前
|
编解码 前端开发 小程序
CSS中rpx、px、em、rem、%、vh、vw各自都代表什么
CSS中rpx、px、em、rem、%、vh、vw各自都代表什么
151 0
|
2月前
|
前端开发 JavaScript UED
CSS 中空格处理
【10月更文挑战第23天】正确处理 CSS 中的空格是实现良好页面布局和视觉效果的重要环节。通过了解空格的基本表现、对布局的影响以及各种处理方法,我们可以更好地掌握空格处理的技巧,为页面设计带来更精致、更专业的呈现。同时,要注意结合具体的项目需求和实际情况,灵活运用这些方法,以满足不同场景下的空格处理要求。
59 7
|
7月前
|
编解码 前端开发 UED
解密CSS单位:px、em、vh的区别与应用
解密CSS单位:px、em、vh的区别与应用
69 1
|
3月前
|
安全 前端开发 开发者
CSS3 中 calc()、constant() 和 env() 函数的使用指南
在现代网页设计中,CSS3 的 calc()、constant() 和 env() 函数为开发者提供了强大的工具,帮助实现灵活和响应式的布局。本文将深入探讨这三个函数的定义、用法以及最佳实践,特别是如何利用 calc() 进行动态计算、constant() 的历史背景,以及 env() 在处理设备安全区域中的应用。通过本文,读者将能够更好地理解并运用这些函数,提升网页设计的灵活性与用户体验。
100 0
|
5月前
|
前端开发 JavaScript Serverless
揭秘CSS布局神器:vw/vh、rem、%与px大PK,掌握它们,让你的网页设计秒变高大上,面试难题迎刃而解!
【8月更文挑战第4天】在Web开发中,合理选择CSS单位对响应式布局至关重要。本文探索viewport单位(vw/vh)、rem、百分比(%)及像素(px)的基础知识与应用场景。通过代码示例,展示如何运用这些单位实现全屏布局、尺寸比例调整、灵活的元素大小及固定尺寸。最后,模拟面试题,介绍如何仅用CSS实现一个元素的高度为其宽度两倍且响应视口变化的方法。
321 8
|
5月前
|
前端开发
css中px和em的区别
css中px和em的区别
72 0
|
5月前
|
前端开发
css中px和em的区别
css中px和em的区别
|
5月前
|
前端开发
CSS——如何使网页字体小于12px
CSS——如何使网页字体小于12px
46 0
|
7月前
|
前端开发 UED 开发者
CSS基础-属性值单位:px, em, rem, %
【6月更文挑战第7天】本文探讨了CSS中四种关键的尺寸单位:像素(px)、相对单位(em)、rem和百分比(%)。px提供稳定显示但不适用于响应式设计;em根据上下文动态调整,但嵌套使用可能导致计算复杂;rem简化了嵌套计算,适合作为响应式设计的选择;%用于流体布局,但可能在复杂结构中引起不稳定。理解各单位特性并结合现代布局技术,能提升网页布局的美观性和用户体验。
95 3

热门文章

最新文章