Home > Web Front-end > CSS Tutorial > How Can I Use CSS Properties as SASS Mixin Values?

How Can I Use CSS Properties as SASS Mixin Values?

Linda Hamilton
Release: 2024-10-27 10:33:02
Original
260 people have browsed it

How Can I Use CSS Properties as SASS Mixin Values?

CSS Property as SASS Mixin Value

When creating universal margin/padding mixins in SASS, you may encounter a concern about setting CSS properties as mixin values. The provided code snippet is an attempt to accomplish this task. However, certain modifications are necessary to make it fully functional.

Solution:

The key to resolving this issue lies in string interpolation. By utilizing the #{$var} notation, one can use variables as property names.

Corrected Code:

[class*="shift"] {
  $sft-o: 10px;
  @mixin shift_stp($val) {
    &[class*="_sml"]{ #{$val}: $sft-o; }
    &[class*="_mid"]{ #{$val}: $sft-o * 2; }
    &[class*="_big"]{ #{$val}: $sft-o * 3; }
  }
  &[class*="_m"]{
    @include shift_stp(margin);
  }
  &[class*="_p"]{
    @include shift_stp(padding);
  }
}
Copy after login

DEMO:

This correction ensures that the CSS property (margin or padding) can be dynamically set based on the mixin's parameter.

Note:

For the attribute selectors ...*="_m", it is worth considering that this selector will apply to all elements containing "_m" in their class name, including those with "_mid" as well. Thus, it may require some re-evaluation and adjustment to achieve the desired specificity.

The above is the detailed content of How Can I Use CSS Properties as SASS Mixin Values?. For more information, please follow other related articles on the PHP Chinese website!

source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Latest Articles by Author
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template