Ошибка Sass Mixin для конкретных фильтров IE, таких как -ms-filter
Я пытаюсь создать комбинацию кнопок следующим образом:
=default_button(!lighter, !darker)
:border= 1px !lighter solid
:background-color #e3e3e3
:background= -webkit-gradient(linear, 0 0, 0 100%, from(!lighter), to(!darker)) repeat-x, #d0581e
:background= -moz-linear-gradient(90deg, !darker, !lighter) repeat-x scroll 0 0 #d0581e
:filter= progid:DXImageTransform.Microsoft.gradient(startColorstr='!lighter', endColorstr='!darker')
:-ms-filter= "progid:DXImageTransform.Microsoft.gradient(startColorstr='!lighter', endColorstr='!darker')"
:zoom 1
:margin 0 0 0 0
:width auto
:padding 2px 14px 2px 14px
:border-radius 10px
:-webkit-border-radius 10px
:-moz-border-radius 10px
:color #FFF
Когда я компилирую sass, я получаю эту ошибку для строк, начинающихся с -filter и -ms-filter:
SASS:: SyntaxError: ожидаемый маркер rparen, был токен single_eq
Я уверен, что это мое размещение =, но я не совсем уверен, как правильно писать. Он работает, если я передаю шестнадцатеричные значения вместо более светлых, более темных, потому что тогда я могу удалить знак = так:
:filter progid:DXImageTransform.Microsoft.gradient(startColorstr='#F89F16', endColorstr='#d0581e')
:-ms-filter "progid:DXImageTransform.Microsoft.gradient(startColorstr='#F89F16', endColorstr='#d0581e')"
Ответы
Ответ 1
Решил это так, но все равно ищет альтернативные предложения наилучшим образом...
=default_button(!lighter, !darker)
text-shadow= 1px 1px 3px darken(!darker, 8)
border= 1px !darker solid
background-color= !lighter
background= -webkit-gradient(linear, 0 0, 0 100%, from(!lighter), to(!darker)) repeat-x, !darker
background= -moz-linear-gradient(90deg, !darker, !lighter) repeat-x scroll 0 0 !darker
-ms-filter = "progid:DXImageTransform.Microsoft.gradient(startColorstr='#{!lighter}', endColorstr='#{!darker}')"
:zoom 1
:margin 0 0 0 0
:width auto
Синтаксис для Sass изменился, поскольку этот ответ был первоначально опубликован. Синтаксис современного синтаксиса выглядит следующим образом:
=default_button($lighter, $darker)
text-shadow: 1px 1px 3px darken($darker, 8)
border: 1px $darker solid
background-color: $lighter
background: -webkit-gradient(linear, 0 0, 0 100%, from($lighter), to($darker)) repeat-x, $darker
background: -moz-linear-gradient(90deg, $darker, $lighter) repeat-x scroll 0 0 $darker
-ms-filter: unquote("progid:DXImageTransform.Microsoft.gradient(startColorstr='#{$lighter}', endColorstr='#{$darker}')")
zoom: 1
margin: 0 0 0 0
width: auto
Ответ 2
Интерполяция #{}
не работает иногда, потому что она уменьшает значения гексагонального цвета. Например, он сократит #334455
до #345
, что нарушит синтаксис фильтра.
SASS имеет новую функцию в версии 3.2: ie-hex-str()
.
Вот как я получил его для работы:
filter: unquote("progid:DXImageTransform.Microsoft.gradient(startColorstr='")
+ ie-hex-str($start)
+ unquote("', endColorstr='")
+ ie-hex-str($stop)
+ unquote("',GradientType=0)"); /* IE6-9 */
Ответ 3
Обновите свой синтаксис, чтобы использовать :
вместо =
для определений свойств:
=mixin($variable)
property: value
property: $variable
Проверьте SASS Reference, хотя примеры находятся в SCSS, а не с отступом SASS. Полный индекс документации SASS.