Части Gulp сценария // «Фрилансер по жизни»

SCSS миксин для подключения шрифтов

@mixin font($font_name, $file_name, $weight, $style) {

@font-face { font-family: $font_name; font-display: swap; src: url("../fonts/#{$file_name}.woff") format("woff"), url("../fonts/#{$file_name}.woff2") format("woff2"); font-weight: #{$weight}; font-style: #{$style}; }

}

JS-функция записи информации в fonts.scss

function fontsStyle(params) {

let file_content = fs.readFileSync(source_folder + '/scss/fonts.scss'); if (file_content == '') { fs.writeFile(source_folder + '/scss/fonts.scss', '', cb); return fs.readdir(path.build.fonts, function (err, items) { if (items) { let c_fontname; for (var i = 0; i < items.length; i++) { let fontname = items[i].split('.'); fontname = fontname[0]; if (c_fontname != fontname) { fs.appendFile(source_folder + '/scss/fonts.scss', '@include font("' + fontname + '", "' + fontname + '", "400", "normal");\r\n', cb); } c_fontname = fontname; } } }) }

}

function cb() { }

JS-функция определения поддержки WebP

function testWebP(callback) {

var webP = new Image(); webP.onload = webP.onerror = function () { callback(webP.height == 2); }; webP.src = "";

}

testWebP(function (support) {

if (support == true) { document.querySelector('body').classList.add('webp'); }else{ document.querySelector('body').classList.add('no-webp'); }

});

Шпаргалка является дополнением к выпуску «Gulp настройка установка плагины»