Using variables for CSS properties in Sass

ぐ巨炮叔叔 提交于 2019-11-26 11:09:23

问题


I am writing a @mixin with some math in it that calculates the percentage width of an element, but since it is very useful I would like to use the same function for other properties too, like margins and paddings.

Is there a way to pass the property name as an argument to a mixin?

@mixin w_fluid($property_name, $w_element,$w_parent:16) {
    $property_name: percentage(($w_element/$w_parent));
}

回答1:


You need to use interpolation (eg. #{$var}) on your variable in order for Sass to treat it as a CSS property. Without it, you're just performing variable assignment.

@mixin w_fluid($property_name, $w_element, $w_parent:16) {
    #{$property_name}: percentage(($w_element / $w_parent));
}



回答2:


In addition to the @rcorbellini response

You can use string and variable together

@mixin margin($direction) { // element spacing

    margin-#{$direction}: 10px;

}


来源:https://stackoverflow.com/questions/15292749/using-variables-for-css-properties-in-sass

标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!