是否可以使用 LESS 设置文件扩展名变量?
这是我正在做的事情的基本概要。
我使用精灵作为我的背景图像并使用 SVG 作为我的文件类型,就像一个魅力。但是,它显然不适用于 IE8-。
我在 Modernizr 中使用了一个很好的检查,如果浏览器不支持它,它会用 .png 扩展名替换 .svg 扩展名:
if (!Modernizr.svg) {
jQuery('img[src$=".svg"]').each(function()
{
jQuery(this).attr('src', jQuery(this).attr('src').replace('.svg', '.png'));
});
}
问题是我正在使用的精灵混合:
@sprite-Grid: 23px;
.sprite(@x, @y) {
background: url(../img/sprite.svg) no-repeat;
background-position: -(@x*@sprite-Grid) -(@y*@sprite-Grid);
}
伟大的小图像替换脚本不适用于背景图像,仅适用于标签。
理想情况下,我要做的是创建一个 LESS 变量,它可以像这样工作:
jQuery
if (!Modernizr.svg) {
jQuery('img[src$=".svg"]').each(function()
{
jQuery(this).attr('src', jQuery(this).attr('src').replace('.svg', '.png'));
});
less.modifyVars({
'@filetype': 'png'
});
} else {
less.modifyVars({
'@filetype': 'svg'
});
}
CSS
figure {
.sprite(0,0,@filetype);
}
@sprite-Grid: 23px;
.sprite(@x, @y, @filetype) {
background: url(../img/sprite.@filetype) no-repeat;
background-position: -(@x*@sprite-Grid) -(@y*@sprite-Grid);
}
简而言之,我想创建一个被传递的变量,它取决于浏览器是否支持 SVG。如果是,则将其更改为“sprite.svg”,如果不是,则将其更改为“sprite.png”
这甚至是一件事吗?
任何帮助是极大的赞赏。