ミキシン値

互換性
Dart Sass
since 1.69.0
LibSass
Ruby Sass

ミキシンも値にすることができます。ミキシンを値として直接記述することはできませんが、meta.get-mixin() 関数にミキシンの名前を渡して値を取得できます。ミキシン値を取得したら、meta.apply() ミキシンに渡して呼び出すことができます。これは、ライブラリを複雑かつ強力に拡張するためのものです。

Playground

SCSS 構文

@use "sass:meta";
@use "sass:string";

/// Passes each element of $list to a separate invocation of $mixin.
@mixin apply-to-all($mixin, $list) {
  @each $element in $list {
    @include meta.apply($mixin, $element);
  }
}

@mixin font-class($size) {
  .font-#{$size} {
    font-size: $size;
  }
}

$sizes: [8px, 12px, 2rem];

@include apply-to-all(meta.get-mixin("font-class"), $sizes);
Playground

Sass 構文

@use "sass:meta"
@use "sass:string"

/// Passes each element of $list to a separate invocation of $mixin.
@mixin apply-to-all($mixin, $list)
  @each $element in $list
    @include meta.apply($mixin, $element)



@mixin font-class($size)
  .font-#{$size}
    font-size: $size



$sizes: 8px, 12px 2rem

@include apply-to-all(meta.get-mixin("font-class"), $sizes)

CSS 出力

.font-8px {
  font-size: 8px;
}

.font-12px {
  font-size: 12px;
}

.font-2rem {
  font-size: 2rem;
}