SCSS - 嵌套

2024-05-09 10:58
文章标签 css frontend 嵌套

本文主要是介绍SCSS - 嵌套,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

嵌套{{}}

嵌套就像下面的样子,先写自身的样式,再嵌套子元素。

嵌套不要超过三层,否则产生难以理解的代码。

 

#a {float: right;.nav {float: left;color: red;ul {width: 400px;li {font-size: 30px;a {color: blue;}&.active {font-weight: bold;}}}}
}

注意&符号,它叫父元素占位符,如果没有父元素占位符,解析之后会是:

 

#a .nav ul li .active {font-weight: bold;
}

#a .nav ul li .active指代什么元素?指代li下面的所有元素中class是active的元素,这根本不是我们的本意,我们的本意是ul下面所有li中class是active的li。所以不能这么写。现在,如果加上&符号,解析之后会是:

 

#a .nav ul li.active {font-weight: bold;
}

这样就符合要求了。所以,&符号指代父元素,当.active并不是li的子元素,而是li自身的一个css状态时,你应该使用&符号。凡是必须将两个选择符连写在一起的场合,包括ele.class、ele:active等等,都适用&。

当一个元素的样式在另一个容器中有其他指定的样式时,可以使用嵌套选择器让他们保持在同一个地方。.no-opacity &相当于.no-opacity .foo

 

.foo {// ….no-opacity & {display: none;}
}

进阶:群组选择器的写法

如果父元素是.container,子元素有h1、h2、h3,他们行高都是1.5em,怎么写?有两种写法:

 

.container h1, .container h2, .container h3 {line-height: 1.5em;
}

 

.container {h1, h2, h3 {line-height: 1.5em;}
}

显然第一种重复了N次.container,是一种愚蠢的写法,下面的写法才是科学的。

总之,任何一级选择器都可以写成组合选择器。

进阶:子组合选择器和同层组合选择器: >、 +和~

子组合选择器的意思是,有一个#id>li列表,如果你明确知道不需要给#id设置任何规则,只想给li设置规则,那么,你就没必要写成下面的样子:

 

#id {li {......}
}

只需要下面这样即可。说白了>并不是SCSS,而是原生css的写法。

 

#id > li {......
}

同样道理,后邻选择符(E+F)和后邻们选择符(E~F)也可以直接用。不过,SASS还有更灵活的用法:

1、把F写到大括号里面,+和~也放到里面。请记住,不要以为大括号里面的元素一定是子元素,还可能是后邻(们)元素。
2、把F写到大括号里面,但是+和~放到外面。下面的dl >就是把>放到了外面,可以少敲几个>。
3、如果都在大括号外面,那就是常规CSS的写法,不多说。

 

article {~ article {border-top: 1px dashed #ccc}> section {background: #eee}dl > {dt {color: #333}dd {color: #555}}nav + & {margin-top: 0}
}

进阶:属性名也可以拆开,用大括号嵌套!

这个就有点牛逼了,凡是带中划线的属性名,都可以拆开,然后用大括号嵌套,让你懒到家。

写法是,把border-style的前半部分写在块外,后面加个冒号,然后把后半部分写到大括号里面即可。将来解析的时候,解析器会自动拼装。

注意绝对不可以忘了加冒号,如果忘了加冒号,就成了最简单的嵌套,就全错了。

 

nav {border: {style: solid;width: 1px;color: #ccc;}
}

更复杂可以这样,外面是一个正常的简写属性和它的值,后面跟个大括号,大括号里面可以声明几个细分属性的后半名称和值:

 

nav {border: 1px solid #ccc {left: 0px;right: 0px;}
}

解析之后是:

 

nav {border: 1px solid #ccc;border-left: 0px;border-right: 0px;
}


 

这篇关于SCSS - 嵌套的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/973221

相关文章

Vue3 如何通过json配置生成查询表单

《Vue3如何通过json配置生成查询表单》本文给大家介绍Vue3如何通过json配置生成查询表单,本文结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录功能实现背景项目代码案例功能实现背景通过vue3实现后台管理项目一定含有表格功能,通常离不开表单

Vue和React受控组件的区别小结

《Vue和React受控组件的区别小结》本文主要介绍了Vue和React受控组件的区别小结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学... 目录背景React 的实现vue3 的实现写法一:直接修改事件参数写法二:通过ref引用 DOMVu

Java实现将HTML文件与字符串转换为图片

《Java实现将HTML文件与字符串转换为图片》在Java开发中,我们经常会遇到将HTML内容转换为图片的需求,本文小编就来和大家详细讲讲如何使用FreeSpire.DocforJava库来实现这一功... 目录前言核心实现:html 转图片完整代码场景 1:转换本地 HTML 文件为图片场景 2:转换 H

C#使用Spire.Doc for .NET实现HTML转Word的高效方案

《C#使用Spire.Docfor.NET实现HTML转Word的高效方案》在Web开发中,HTML内容的生成与处理是高频需求,然而,当用户需要将HTML页面或动态生成的HTML字符串转换为Wor... 目录引言一、html转Word的典型场景与挑战二、用 Spire.Doc 实现 HTML 转 Word1

Vue3绑定props默认值问题

《Vue3绑定props默认值问题》使用Vue3的defineProps配合TypeScript的interface定义props类型,并通过withDefaults设置默认值,使组件能安全访问传入的... 目录前言步骤步骤1:使用 defineProps 定义 Props步骤2:设置默认值总结前言使用T

详解Java中三种状态机实现方式来优雅消灭 if-else 嵌套

《详解Java中三种状态机实现方式来优雅消灭if-else嵌套》这篇文章主要为大家详细介绍了Java中三种状态机实现方式从而优雅消灭if-else嵌套,文中的示例代码讲解详细,感兴趣的小伙伴可以跟... 目录1. 前言2. 复现传统if-else实现的业务场景问题3. 用状态机模式改造3.1 定义状态接口3

基于Python Playwright进行前端性能测试的脚本实现

《基于PythonPlaywright进行前端性能测试的脚本实现》在当今Web应用开发中,性能优化是提升用户体验的关键因素之一,本文将介绍如何使用Playwright构建一个自动化性能测试工具,希望... 目录引言工具概述整体架构核心实现解析1. 浏览器初始化2. 性能数据收集3. 资源分析4. 关键性能指

从入门到精通详解LangChain加载HTML内容的全攻略

《从入门到精通详解LangChain加载HTML内容的全攻略》这篇文章主要为大家详细介绍了如何用LangChain优雅地处理HTML内容,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录引言:当大语言模型遇见html一、HTML加载器为什么需要专门的HTML加载器核心加载器对比表二

Python中将嵌套列表扁平化的多种实现方法

《Python中将嵌套列表扁平化的多种实现方法》在Python编程中,我们常常会遇到需要将嵌套列表(即列表中包含列表)转换为一个一维的扁平列表的需求,本文将给大家介绍了多种实现这一目标的方法,需要的朋... 目录python中将嵌套列表扁平化的方法技术背景实现步骤1. 使用嵌套列表推导式2. 使用itert

前端如何通过nginx访问本地端口

《前端如何通过nginx访问本地端口》:本文主要介绍前端如何通过nginx访问本地端口的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、nginx安装1、下载(1)下载地址(2)系统选择(3)版本选择2、安装部署(1)解压(2)配置文件修改(3)启动(4)