Het &
personage in Sass is uniek omdat het de huidige selector vertegenwoordigt. Het verandert terwijl je nest. Laten we zeggen dat u genest bent, maar dat u toegang wilt tot een selector om een back-up te maken van het nesten. De truc is om te cachen & en het dieper in het nest te gebruiken. Leuk vinden:
.parent ( $this: &; &--elem ( display: inline-block; &:hover, #($this)__variation--active & ( background: red; ) ) )
Welke compileert naar:
.parent--elem ( display: inline-block; ) .parent--elem:hover, .parent__variation--active .parent--elem ( background: red; )
(Met dank aan Sergey Kovalenko voor het insturen van deze truc!)
Dit betekent dat u .parent
en .parent--elem
binnen een selector tegelijkertijd kunt gebruiken. Een beetje esoterisch, maar kan soms nuttig zijn. Een soort van vermijdt situaties waarin je @ at-root moet gebruiken om helemaal terug te gaan en selectors opnieuw te maken.
Sergey's kern heeft voorbeelden die op BEM zijn gebaseerd:
- Page 1
- Page 2
$gray-very-light: #ccc; .pagination ( display: flex; padding: 0; list-style: none; $this: &; &__item ( border: 1px solid $gray-very-light; & + & ( margin-left: .5rem; ) ) &__link ( display: block; padding: .25rem .5rem; text-decoration: none; &:hover, #($this)__item--active & ( // Here we get .pagination from $this variable background-color: $gray-very-light; ) ) )
Uitgang:
.pagination ( display: flex; padding: 0; list-style: none; ) .pagination__item ( border: 1px solid #ccc; ) .pagination__item + .pagination__item ( margin-left: .5rem; ) .pagination__link ( display: block; padding: .25rem .5rem; text-decoration: none; ) .pagination__link:hover, .pagination__item--active .pagination__link ( background-color: #ccc; )