你也许会不时地写写 Sass 玩玩,你也会很享受它带给你各种便利。但还有一件事,你并不一定完全了解:插值 (interpolation) - 将一个占位符,替换成一个值。好了,你们都很幸运,因为今天我将把这种问题说清楚。
插值。啥玩意儿?
插值,通常是指变量插值,或者变量替换。这不是Sass独有的。实际上,你可以在很多编程语言中,发现这种特性。比如 PHP, Perl, Ruby, Tcl, Groovy, Unix shells, 等等。我们经常说的是,插入一个变量,或者插入一个表达式。
我们还是先来看看一个例子吧。如果你有PHP的基础,接下来应该会很容易了解。比如说,你想打印一个包含变量的字符串,最常见的方式:
$description = "awesome"; echo "Tuts+ is " . $description . "!";
这就不是插值的方式,你这是字符串的连接。这其中,连接了三个字符串:"Tuts+ is ",awesome(被 $description所引用) 以及 "!"。现在,我们就来看看使用插值而非字符串连接的方式:
$description = "awesome"; echo "Tuts+ is ${description}!";
包裹在变量两边的花括号会告诉PHP,用字符串打印出变量的值。值得注意的是:它需要在双引号里面才可以工作(大多语言都是这样)。
不管怎样,这就是变量/表达式插值。是使用字符串连接,还是使用插值,这都取决于你自己。但可以说一点:插值其实就是字符串连接的语法糖而已。
Sass的插值
我们先看看在Sass中,变量替换是怎么工作。
Sass变量的命名,就像PHP一样,都有着美元符号的前缀($)。两者的对比,显得就结束了,因为谈到插值,两者的表现是不同的。有一个很好的解释是:Sass是基于Ruby的,它使用 ${}进行表达式替换。
在Sass中,你会这样做:
$description: "awesome"; @warn "Tuts+ is #{$description}!";
需要注意的是,变量中的$ 不能像PHP一样丢掉。变量被#{}包裹了起来。另外值得一提的是:你可以插入任何类型的变量,不仅仅是字符串。
比如:
$answer: 42; @warn "The Answer to the Ultimate Question of Life, the Universe, and Everything is #{$answer}.";
什么时候应该使用插值
现在你应该明白什么是插值了,也知道怎么在Sass中工作的了。是时候,开始着手实际场景了。首先,我们会再次使用刚才做过的@warn指令,它将打印相应内容到控制台。
字符串 (Strings)
假设你有一组叫$colors名的颜色映射(映射是指一个存储了一系列 key/value 组合的变量),但你已经受够了一次又一次地敲 map-get($colors, ...)。所以,你写了一个简单的color()函数,使用key去获得相应的值。
把这些组合一下就是:
// _config.scss $colors: ( "primary": tomato, "secondary": hotpink ); // _function.scss @function color($key) { @return map-get($colors, $key); } // _component.scss .el { background-color: color(primary); }
一切都很好,不是吗?现在,当你敲错名称,或者去取一个不存在的key时,你想给出错误的信息。这将通过 @warn指令来完成。color()函数如下:
@function color($key) { @if not map-has-key($colors, $key) { @warn "Key not found."; } @return map-get($colors, $key); }
还不错。如果你想知道哪个key没有找到呢?
@function color($key) { @if not map-has-key($colors, $key) { @warn "Key `#{$key}` not found."; } @return map-get($colors, $key); }
嘣~~变量插值。调用 color(awesomeness) 时,将会抛出以下信息:
Key awesomeness not found
这真的很棒,但我们却不知道上下文是什么。为使后来的方便,我们可以将映射的名称写到错误信息里面。
@function color($key) { @if not map-has-key($colors, $key) { @warn "Key `#{$key}` not found in $colors map."; } @return map-get($colors, $key); }
在这个场景里,由于这个 $colors 变量没有使用插值,它将打印以下信息:
Key awesomeness not found in $colors map.
CSS函数 (Functions)
到目前为止,我们已经见到了最常见的变量替换场景:打印字符串中变量的内容。这确实是一个好的示例,但我觉得应该还有更好的场景:CSS函数中的变量,比如 calc()。
假设你想基于侧边栏的宽度设置主容器的大小。你是一个勤奋的前端开发者,已经把这个宽度存储在一个变量中,所以,你可能会这样做:
$sidebar-width: 250px; .main { width: calc(100% - $sidebar-width); }
然后,你会惊讶地发现,根本不work。没有报错,容器的大小却又不正确。如果你去审查你的dom元素,你会看到这个 ? 被划掉了。因为,这是不合法的。
.main { width: calc(100% - $sidebar-width); }
现在我们应该想到:calc() 是一个CSS函数,不是一个Sass函数。这就是说Sass会将整个表达式解释成一个字符串。你可以试试:
$type-of-expression: type-of(calc(100% - $sidebar-width)); // string
因为这是一个字符串,难怪Sass表现和之前@warn中的$colors字符串一样。$sidebar-width被认为是一个常规字符串,所以打出来就是它自己。但这都不是我们所想要的,是吧?我们用插值这样做。
.main { width: calc(100% - #{$sidebar-width}); }
现在当Sass编译这个样式文件时,它会用#{$sidebar-width}的值,250px替换#{$sidebar-width}。最后,便是合法的CSS表达式。
.main { width: calc(100% - 250px); }
任务完成!我们仅仅在这里谈了calc(),但其实和其他CSS 原生函数是一样的,包括伪类。比如:url(),linear-gradient(),radial-gradient(),cubic-bezier()。
以下是另一个使用CSS函数的例子:
@for $i from 1 through $max { .el:nth-of-type(#{$i}) { // ... } }
这是一个你有可能遇到过的场景:for循环和:nth-*()选择器一起使用。再一次说明,你需要使用插值变量,才能最终得到想得到的结果。
小结:Sass会把CSS函数认为是字符串,所以想要在最后获得它们的值,要求你转义所有同它们一起使用的变量。
CSS指令 (Directives)
我们将视转移到另一个有趣的变量插值场景:CSS指令,比如@support,@page,最重要的还是@media。
现在,Sass是怎样解析CSS指令,尤其是demia指令的。我已经查看过Sass的源码,当我Ruby环境有点问题的时候,我找到一些有趣的事情。
def query_expr interp = interpolation return interp if interp return unless tok(/\(/) res = ['('] ss res << sass_script(:parse) if tok(/:/) res << ': ' ss res << sass_script(:parse) end res << tok!(/\)/) ss res end
第一行告诉Sass,如果有一个插值表达式的话,便返回media query。如果找到一个开括号((),便会一直往下走,解析所有的东西,反之就会抛出一个错误。我们在这里试试一个例子:
$value: screen; @media $value { // ... }
毫不惊讶的是,这失败了:
Invalid CSS after "@media (" at media) ": expected media query (e.g. print, screen, print and screen), was "$value {"
就像错误信息提示的那样,它期待一个media query。在这里,如果你的变量在 @media 字符串后面,需要使用插值才可以。比如:
$value: screen; @media #{$value} { // ... }
和我们之前讨论的Ruby转义规则一样,如果@media后面紧跟(()),你就不再需要插值变量了,因为Sass会求出所有在这些括号里面的值。比如:
$value: 1336px; @media (max-width: $value) { // ... }
在这个示例中,Sass将这个表达式(max-width: $value)转化成(max-width: 1337px),最后生成合法的CSS结果。所以,我们便没有必要再对变量转义了。
选择器 (Selectors)
好的,这将是最后一个示例:使用变量作为一个选择器,或者选择器的一部分。这不是一种常用的用法,以下的做法不太符合常识:
$value: custom; selector-$value { property: value; }
不幸的是,这根本无法编译成功:
Invalid CSS after "selector-": expected "{", was "$value {"
这是media query那个例子的原因,差不多。Sass有着自己的方式解析一个CSS选择器。如果它遇到了不可预知的东西,比如一个未经处理的美元符号,它就会直接崩溃。
幸运的,解决这个问题也相当简单(你也已经知道怎么做了):没错,使用插值变量!
$value: custom; selector-#{$value} { property: value; }
结语
在最后,Sass的插值没有看起来那么简单。在一些示例之中,你必须转义你的变量,一些示例中,你却不必。如果是那样,你有两种方式处理:
不管怎样,我希望你明白了插值变量是如何工作的。如果你有什么需要添加的,请在留言中指出。

HTML是一种用于构建网页的语言,通过标签和属性定义网页结构和内容。1)HTML通过标签组织文档结构,如、。2)浏览器解析HTML构建DOM并渲染网页。3)HTML5的新特性如、、增强了多媒体功能。4)常见错误包括标签未闭合和属性值未加引号。5)优化建议包括使用语义化标签和减少文件大小。

WebDevelovermentReliesonHtml,CSS和JavaScript:1)HTMLStructuresContent,2)CSSStyleSIT和3)JavaScriptAddSstractivity,形成thebasisofmodernWebemodernWebExexperiences。

HTML的作用是通过标签和属性定义网页的结构和内容。1.HTML通过到、等标签组织内容,使其易于阅读和理解。2.使用语义化标签如、等增强可访问性和SEO。3.优化HTML代码可以提高网页加载速度和用户体验。

htmlisaspecifictypefodyfocusedonstructuringwebcontent,而“代码” badlyLyCludEslanguagesLikeLikejavascriptandPytyPythonForFunctionality.1)htmldefineswebpagertuctureduseTags.2)“代码”代码“ code” code code code codeSpassSesseseseseseseseAwiderRangeLangeLangeforLageforLogageforLogicIctInterract

HTML、CSS和JavaScript是Web开发的三大支柱。1.HTML定义网页结构,使用标签如、等。2.CSS控制网页样式,使用选择器和属性如color、font-size等。3.JavaScript实现动态效果和交互,通过事件监听和DOM操作。

HTML定义网页结构,CSS负责样式和布局,JavaScript赋予动态交互。三者在网页开发中各司其职,共同构建丰富多彩的网站。

HTML适合初学者学习,因为它简单易学且能快速看到成果。1)HTML的学习曲线平缓,易于上手。2)只需掌握基本标签即可开始创建网页。3)灵活性高,可与CSS和JavaScript结合使用。4)丰富的学习资源和现代工具支持学习过程。

AnexampleOfAstartingTaginHtmlis,beginSaparagraph.startingTagSareEssentialInhtmlastheyInitiateEllements,defiteTheeTheErtypes,andarecrucialforsstructuringwebpages wepages webpages andConstructingthedom。


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

WebStorm Mac版
好用的JavaScript开发工具

SublimeText3汉化版
中文版,非常好用

Dreamweaver Mac版
视觉化网页开发工具

mPDF
mPDF是一个PHP库,可以从UTF-8编码的HTML生成PDF文件。原作者Ian Back编写mPDF以从他的网站上“即时”输出PDF文件,并处理不同的语言。与原始脚本如HTML2FPDF相比,它的速度较慢,并且在使用Unicode字体时生成的文件较大,但支持CSS样式等,并进行了大量增强。支持几乎所有语言,包括RTL(阿拉伯语和希伯来语)和CJK(中日韩)。支持嵌套的块级元素(如P、DIV),

Atom编辑器mac版下载
最流行的的开源编辑器