в зависимости от того, как ваши пакеты структурированы / применены, вы можете использовать цикл для генерации набора общих стилей. См. Документацию здесь: http://sass -lang.com / docs / yardoc / file.SASS_REFERENCE.html # id35
Вам действительно нужно 3 отдельных компонента, чтобы получить URL-адрес изображения? не так: $img
, а затем установить значение /folder/img.ext
будет намного проще?
Кроме того, вам не нужно #{}
для повторения, кстати.
Надеюсь, это то, что вы ищете ... вопрос не очень конкретный с точки зрения того, каким вам нужен результат на самом деле.
Ура,
Jannis
Обновление:
Хорошо, я вижу, вы обновили свой вопрос (спасибо за это). Я считаю, что это может быть немного лучше для общего использования:
@mixin background($imgpath,$position:0 0,$repeat: no-repeat) {
background: {
image: url($imgpath);
position: $position;
repeat: $repeat;
}
}
.testing {
@include background('/my/img/path.png');
}
Затем будет выведено:
.testing {
background-image: url("/my/img/path.png");
background-position: 0 0;
background-repeat: no-repeat;
}
Или вы можете использовать сокращенную версию:
@mixin backgroundShorthand($imgpath,$position:0 0,$repeat: no-repeat) {
background: transparent url(#{$imgpath}) $repeat $position;
}
.testing2 {
@include backgroundShorthand('/my/img/path.png');
}
Который будет генерировать:
.testing2 {
background: transparent url(/my/img/path.png) no-repeat 0 0;
}
И, наконец, , если вы хотите указать свой базовый путь к каталогу изображений отдельно , вы можете сделать следующее:
$imagedir:'/static/images/'; // define the base path before the mixin
@mixin backgroundShorthandWithExternalVar($filename,$position:0 0,$repeat: no-repeat) {
background: transparent url(#{$imagedir}#{$filename}) $repeat $position;
}
.testing3 {
@include backgroundShorthandWithExternalVar('filename.png');
}
Затем будет сгенерировано:
.testing3 {
background: transparent url(/static/images/filename.png) no-repeat 0 0;
}
Это то, что вам нужно?
Если не стесняйтесь обновить вопрос или ответ / комментарий.