From c202b18c7d76857d61d179b8634e509170601ce2 Mon Sep 17 00:00:00 2001 From: Andrei Calinescu Date: Thu, 16 Jun 2022 23:12:24 +0900 Subject: [PATCH] add CSS - combining multiple selectors --- README.md | 1 + css/combining-multiple-selectors.md | 61 +++++++++++++++++++++++++++++ 2 files changed, 62 insertions(+) create mode 100644 css/combining-multiple-selectors.md diff --git a/README.md b/README.md index 5170033..a4c255f 100644 --- a/README.md +++ b/README.md @@ -18,6 +18,7 @@ This repo is inspired by the [@jbrandchaud/til](https://github.com/jbranchaud/ti ### CSS +- [Combining multiple selectors](css/combining-multiple-selectors.md) - [`font-size` in Safari only supports integers](css/font-size-in-safari-only-supports-integers.md) ### Cypress diff --git a/css/combining-multiple-selectors.md b/css/combining-multiple-selectors.md new file mode 100644 index 0000000..a52f0fc --- /dev/null +++ b/css/combining-multiple-selectors.md @@ -0,0 +1,61 @@ +# Combining multiple selectors + +What is the difference between these 2 selectors? They're very subtly different, but their effects are not. + +```css +#header .callout { + /* Select .callout elements if they are CHILDREN of #header */ +} +#header.callout { + /* Select elements with BOTH both those selectors */ +} +``` + +## With a space (`#A .B`) + +The `space` between selectors signifies a `parent > child` relationship. `B` MUST be the child of `A`. + +```swift +// #header .callout +element.PARENT.id === "header" && element.class === "callout" +// Select all elements with the class name callout that are decendents of the element with an ID of header. +``` + +## Concatenated (`#A.B`) + +All concatenated selectors MUST match. `B` MUST be the child of `A`. + +```swift +// #header.callout +element.id === "header" && element.class === "callout" +//Select the element which has an ID of header and also a class name of callout. +``` + +![image](https://user-images.githubusercontent.com/24983797/174083930-0c5c5450-ba09-4384-b34a-531ddd6226dd.png) + +## Going overboard + +You can combine multiple `class` and `id` selectors. The snippets below are valid, but they're not nice to look at. + +> We aren’t limited to only two here, we can combine as many classes and IDs into a single selector as we want. +> +> Although bear in mind that’s getting a little ridiculous =) + +```css +.snippet#header.code.red { + color: red; +} +``` + +And here's the longest combined selector I've felt the need to use, at least as a proof of concept before refactoring. I'm sorry you had to see this. It's pretty cool that you can combine pseudo-classes too though! + +PS. I blame a very ambitious and customized design system that needs to be coded and documented in Storybook 🤷‍♂️. + +```css +.storybook-scroll--large:hover.storybook-scroll--horizontal:hover.storybook-scroll--hidden-true:hover { +} +``` + +## Credits + +- CSS Tricks [article](https://css-tricks.com/multiple-class-id-selectors/).