{"id":269746,"date":"2015-12-07T11:01:02","date_gmt":"2015-12-07T08:01:02","guid":{"rendered":"http:\/\/savepearlharbor.com\/?p=269746"},"modified":"-0001-11-30T00:00:00","modified_gmt":"-0001-11-29T21:00:00","slug":"","status":"publish","type":"post","link":"https:\/\/savepearlharbor.com\/?p=269746","title":{"rendered":"\u041a\u0430\u043a \u044f \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044e SVG-\u0441\u043f\u0440\u0430\u0439\u0442\u044b"},"content":{"rendered":"<p>       \u041f\u0440\u0438\u0432\u0435\u0442, \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a!<br \/>  \u041f\u0440\u0438 \u0432\u0435\u0440\u0441\u0442\u043a\u0435 \u043c\u0430\u043a\u0435\u0442\u0430 \u0438\u0437 PSD \u0447\u0430\u0441\u0442\u043e \u0438\u043a\u043e\u043d\u043a\u0438 \u0432\u0441\u0442\u0430\u0432\u043b\u0435\u043d\u044b \u0432 \u0444\u043e\u0440\u043c\u0430\u0442\u0435 SVG. \u0410 \u0435\u0441\u043b\u0438 \u043d\u0435\u0442 \u2014 \u043f\u0440\u043e\u0448\u0443 \u0438\u0445 \u0443 \u0434\u0438\u0437\u0430\u0439\u043d\u0435\u0440\u0430. \u0420\u0430\u043d\u0435\u0435 \u044f \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043b \u0438\u043a\u043e\u043d\u043e\u0447\u043d\u044b\u0435 \u0448\u0440\u0438\u0444\u0442\u044b, \u043d\u043e \u043d\u0435\u0434\u0430\u0432\u043d\u043e \u0443\u0432\u0438\u0434\u0435\u043b \u043f\u0440\u0435\u0438\u043c\u0443\u0449\u0435\u0441\u0442\u0432\u0430 \u0441\u043f\u0440\u0430\u0439\u0442\u043e\u0432 \u0438 \u0440\u0435\u0448\u0438\u043b \u043f\u043e\u043f\u0440\u043e\u0431\u043e\u0432\u0430\u0442\u044c <s>\u0441 \u043d\u0438\u043c\u0438 \u043f\u043e\u0438\u0433\u0440\u0430\u0442\u044c\u0441\u044f<\/s> \u0432\u043d\u0435\u0434\u0440\u0438\u0442\u044c \u0438\u0445 \u0432 \u043f\u0440\u043e\u0446\u0435\u0441\u0441 \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u043a\u0438. \u041c\u043d\u0435 \u043d\u0440\u0430\u0432\u044f\u0442\u0441\u044f \u0438\u043a\u043e\u043d\u043e\u0447\u043d\u044b\u0435 \u0448\u0440\u0438\u0444\u0442\u044b, \u043d\u043e \u043e\u043d\u0438 \u0438\u043c\u0435\u044e\u0442 \u0440\u044f\u0434 \u043d\u0435\u0434\u043e\u0441\u0442\u0430\u0442\u043a\u043e\u0432(\u043d\u0430 \u044d\u0442\u0443 \u0442\u0435\u043c\u0443 \u043f\u043e\u0447\u0438\u0442\u0430\u0439\u0442\u0435 <a href=\"https:\/\/css-tricks.com\/icon-fonts-vs-svg\/\">CSSTricks<\/a>). \u042d\u043a\u0441\u043f\u0435\u0440\u0438\u043c\u0435\u043d\u0442 \u0443\u0434\u0430\u043b\u0441\u044f, \u0438 \u0432\u043e\u0442 \u043a\u0430\u043a \u044f \u043e\u0440\u0433\u0430\u043d\u0438\u0437\u043e\u0432\u0430\u043b \u0441\u0438\u0441\u0442\u0435\u043c\u0443.<br \/>  <a name=\"habracut\"><\/a>  <\/p>\n<h4>\u0423\u0441\u043b\u043e\u0432\u0438\u044f<\/h4>\n<p>  \u0427\u0442\u043e \u044f \u0445\u043e\u0447\u0443 \u043f\u043e\u043b\u0443\u0447\u0438\u0442\u044c \u043e\u0442 \u0441\u043f\u0440\u0430\u0439\u0442\u043e\u0432:  <\/p>\n<ol>\n<li>\u0413\u0438\u0431\u043a\u043e\u0435 \u0443\u043f\u0440\u0430\u0432\u043b\u0435\u043d\u0438\u0435 \u0440\u0430\u0437\u043c\u0435\u0440\u043e\u043c, \u0446\u0432\u0435\u0442\u043e\u043c \u0438 \u043f\u043e\u0432\u0435\u0434\u0435\u043d\u0438\u0435\u043c(hover, focus etc) \u0438\u043a\u043e\u043d\u043a\u0438<\/li>\n<li>\u0410\u0432\u0442\u043e\u043c\u0430\u0442\u0438\u0437\u0430\u0446\u0438\u044f, \u043c\u0438\u043d\u0438\u043c\u0443\u043c \u0440\u0443\u0447\u043d\u043e\u0439 \u0440\u0430\u0431\u043e\u0442\u044b <\/li>\n<li>\u041a\u0435\u0448\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u0435 \u0438\u043a\u043e\u043d\u043e\u043a \u0434\u043b\u044f \u0445\u043e\u0440\u043e\u0448\u0435\u0439 \u0441\u043a\u043e\u0440\u043e\u0441\u0442\u0438 \u0437\u0430\u0433\u0440\u0443\u0437\u043a\u0438 \u0441\u0442\u0440\u0430\u043d\u0438\u0446 <\/li>\n<li>\u0423\u0434\u043e\u0431\u043d\u0430\u044f \u0432\u0441\u0442\u0430\u0432\u043a\u0430 \u0438\u043a\u043e\u043d\u043e\u043a \u0432 \u0440\u0430\u0437\u043c\u0435\u0442\u043a\u0443 \u0441\u0442\u0440\u0430\u043d\u0438\u0446\u044b (\u0434\u043b\u044f \u0448\u0430\u0431\u043b\u043e\u043d\u0438\u0437\u0430\u0446\u0438\u0438 html \u044f \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044e jade)<\/li>\n<\/ol>\n<p>  \u041c\u043e\u044f \u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0430 \u043f\u0430\u043f\u043e\u043a:  <\/p>\n<pre><code class=\"javascript\">\u251c\u2500\u2500 gulpfile.js                # gulpfile \u2514\u2500\u2500assets                      # \u0437\u0434\u0435\u0441\u044c \u0440\u0435\u0434\u0430\u043a\u0442\u0438\u0440\u0443\u0435\u043c \u0444\u0430\u0439\u043b\u044b     \u2514\u2500\u2500 jade\/                  # \u0448\u0430\u0431\u043b\u043e\u043d\u0438\u0437\u0430\u0442\u043e\u0440 html     \u2514\u2500\u2500 sass\/                  # \u0441\u0442\u0438\u043b\u0438     \u2514\u2500\u2500 js\/                    # \u0441\u043a\u0440\u0438\u043f\u0442\u044b     \u2514\u2500\u2500 i\/                     # \u043a\u0430\u0440\u0442\u0438\u043d\u043a\u0438, \u0441\u044e\u0434\u0430 \u043c\u044b \u0438 \u0431\u0443\u0434\u0435\u043c \u0432\u0441\u0442\u0430\u0432\u043b\u044f\u0442\u044c \u0441\u043f\u0440\u0430\u0439\u0442 \u2514\u2500\u2500dist                        # \u0437\u0434\u0435\u0441\u044c \u043f\u043e\u043b\u0443\u0447\u0430\u0435\u043c \u0433\u043e\u0442\u043e\u0432\u044b\u0439 \u043f\u0440\u043e\u0435\u043a\u0442 <\/code><\/pre>\n<p>  \u041f\u043e\u0434\u0440\u043e\u0431\u043d\u0435\u0435 \u043e \u0442\u043e\u043c \u043a\u0430\u043a \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u043c\u043e\u044f \u0441\u0431\u043e\u0440\u043a\u0430 \u2014 \u043c\u043e\u0436\u0435\u0442\u0435 \u043f\u043e\u0447\u0438\u0442\u0430\u0442\u044c <a href=\"https:\/\/github.com\/gatilin222\/supervisor_template\">\u0432 \u0440\u0435\u043f\u043e\u0437\u0438\u0442\u043e\u0440\u0438\u0438<\/a>. <br \/>  \u0414\u043b\u044f \u0441\u043e\u0437\u0434\u0430\u043d\u0438\u044f \u0441\u043f\u0440\u0430\u0439\u0442\u0430 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u043c gulp, \u0430 \u0438\u043c\u0435\u043d\u043d\u043e:  <\/p>\n<ul>\n<li><b>gulp-svg-sprites<\/b> \u2014 \u0441\u043e\u0437\u0434\u0430\u043d\u0438\u0435 \u0441\u043f\u0440\u0430\u0439\u0442\u0430<\/li>\n<li><b>gulp-svgmin<\/b> \u2014 \u043c\u0438\u043d\u0438\u0444\u0438\u043a\u0430\u0446\u0438\u044f SVG <\/li>\n<li><b>gulp-cheerio<\/b> \u2014 \u0443\u0434\u0430\u043b\u0435\u043d\u0438\u0435 \u043b\u0438\u0448\u043d\u0438\u0445 \u0430\u0442\u0440\u0438\u0431\u0443\u0442\u043e\u0432 \u0438\u0437 svg <\/li>\n<li> <b>gulp-replace<\/b> \u2014 \u0444\u0438\u043a\u0441\u0438\u043d\u0433 \u043d\u0435\u043a\u043e\u0442\u043e\u0440\u044b\u0445 \u0431\u0430\u0433\u043e\u0432, \u043e\u0431 \u044d\u0442\u043e\u043c \u043d\u0438\u0436\u0435<\/li>\n<\/ul>\n<h4>\u041f\u043e\u0435\u0445\u0430\u043b\u0438!<\/h4>\n<p>  \u0423\u0441\u0442\u0430\u043d\u0430\u0432\u043b\u0438\u0432\u0430\u0435\u043c \u043f\u043b\u0430\u0433\u0438\u043d\u044b(\u044f \u044d\u0442\u043e \u0434\u0435\u043b\u0430\u044e \u0433\u043b\u043e\u0431\u0430\u043b\u044c\u043d\u043e \u0438 \u043f\u043e\u0442\u043e\u043c \u043b\u0438\u043d\u043a\u0443\u044e):  <\/p>\n<pre><code class=\"javascript\">npm install gulp-svg-sprites gulp-svgmin gulp-cheerio gulp-replace -g npm link gulp-svg-sprites gulp-svgmin gulp-cheerio gulp-replace <\/code><\/pre>\n<p>  \u0412 gulpfile \u043e\u0431\u044a\u044f\u0432\u043b\u044f\u0435\u043c \u043f\u043b\u0430\u0433\u0438\u043d\u044b:  <\/p>\n<pre><code class=\"javascript\">var svgSprite = require('gulp-svg-sprites'), \tsvgmin = require('gulp-svgmin'), \tcheerio = require('gulp-cheerio'), \treplace = require('gulp-replace'); <\/code><\/pre>\n<h4>\u0412\u0430\u0440\u0438\u043c \u0441\u043f\u0440\u0430\u0439\u0442<\/h4>\n<p>  \u041f\u0435\u0440\u0432\u044b\u0439 \u0442\u0430\u0441\u043a \u2014 \u0441\u043e\u0437\u0434\u0430\u0435\u043c html-\u0444\u0430\u0439\u043b \u0441 \u0442\u0435\u0433\u0430\u043c\u0438 <b>symbol<\/b>.  <\/p>\n<pre><code class=\"javascript\">gulp.task('svgSpriteBuild', function () { \treturn gulp.src(assetsDir + 'i\/icons\/*.svg') \t\t\/\/ minify svg \t\t.pipe(svgmin({ \t\t\tjs2svg: { \t\t\t\tpretty: true \t\t\t} \t\t})) \t\t\/\/ remove all fill and style declarations in out shapes \t\t.pipe(cheerio({ \t\t\trun: function ($) { \t\t\t\t$('[fill]').removeAttr('fill'); \t\t\t\t$('[style]').removeAttr('style'); \t\t\t}, \t\t\tparserOptions: { xmlMode: true } \t\t})) \t\t\/\/ cheerio plugin create unnecessary string '&gt;', so replace  \t\t.pipe(replace('&g t;', '&gt;')) \/\/ remove space between 'g' and 't' letters \t\t\/\/ build svg sprite \t\t.pipe(svgSprite({ \t\t\t\tmode: &quot;symbols&quot;, \t\t\t\tpreview: false, \t\t\t\tselector: &quot;icon-%f&quot;, \t\t\t\tsvg: { \t\t\t\t\tsymbols: 'symbol_sprite.html' \t\t\t\t} \t\t\t} \t\t)) \t\t.pipe(gulp.dest(assetsDir + 'i\/')); });)); }); <\/code><\/pre>\n<p>  \u0414\u0430\u0432\u0430\u0439\u0442\u0435 \u0440\u0430\u0437\u0431\u0435\u0440\u0435\u043c\u0441\u044f, \u0447\u0442\u043e \u0442\u0443\u0442 \u043f\u0440\u043e\u0438\u0441\u0445\u043e\u0434\u0438\u0442 \u043f\u043e \u0447\u0430\u0441\u0442\u044f\u043c.<br \/>  \u0413\u043e\u0432\u043e\u0440\u0438\u043c \u043e\u0442\u043a\u0443\u0434\u0430 \u043d\u0430\u043c \u043d\u0443\u0436\u043d\u043e \u0432\u0437\u044f\u0442\u044c \u0438\u043a\u043e\u043d\u043a\u0438 \u0438 \u043c\u0438\u043d\u0438\u0444\u0438\u0446\u0438\u0440\u0443\u0435\u043c \u0438\u0445. \u041f\u0435\u0440\u0435\u043c\u0435\u043d\u043d\u0430\u044f assetsDir \u2014 \u0434\u043b\u044f \u0443\u0434\u043e\u0431\u0441\u0442\u0432\u0430.  <\/p>\n<pre><code class=\"javascript\">return gulp.src(assetsDir + 'i\/icons\/*.svg') \t\/\/ minify svg \t.pipe(svgmin({ \t\tjs2svg: { \t\t\tpretty: true \t\t} \t})) <\/code><\/pre>\n<p>  \u0423\u0434\u0430\u043b\u044f\u0435\u043c \u0430\u0442\u0440\u0438\u0431\u0443\u0442\u044b style \u0438 fill \u0438\u0437 \u0438\u043a\u043e\u043d\u043e\u043a, \u0434\u043b\u044f \u0442\u043e\u0433\u043e \u0447\u0442\u043e\u0431\u044b \u043e\u043d\u0438 \u043d\u0435 \u043f\u0435\u0440\u0435\u0431\u0438\u0432\u0430\u043b\u0438 \u0441\u0442\u0438\u043b\u0438, \u0437\u0430\u0434\u0430\u043d\u043d\u044b\u0435 \u0447\u0435\u0440\u0435\u0437 css.  <\/p>\n<pre><code class=\"javascript\">.pipe(cheerio({ \trun: function ($) { \t\t$('[fill]').removeAttr('fill'); \t\t$('[style]').removeAttr('style'); \t}, \tparserOptions: { xmlMode: true } })) <\/code><\/pre>\n<p>  \u041d\u043e \u044f \u0437\u0430\u043c\u0435\u0442\u0438\u043b \u0443 \u0434\u0430\u043d\u043d\u043e\u0433\u043e \u043f\u043b\u0430\u0433\u0438\u043d\u0430 \u043e\u0434\u0438\u043d \u0431\u0430\u0433 \u2014 \u0438\u043d\u043e\u0433\u0434\u0430 \u043e\u043d \u043f\u0440\u0435\u043e\u0431\u0440\u0430\u0437\u043e\u0432\u044b\u0432\u0430\u0435\u0442 \u0441\u0438\u043c\u0432\u043e\u043b &#8216;&gt;&#8217; \u0432 \u043a\u043e\u0434\u0438\u0440\u043e\u0432\u043a\u0443 &#8216;&#038;g t;&#8217;, \u0442\u043e\u043b\u044c\u043a\u043e \u0431\u0435\u0437 \u043f\u0440\u043e\u0431\u0435\u043b\u0430 \u043c\u0435\u0436\u0434\u0443 \u0441\u0438\u043c\u0432\u043e\u043b\u0430\u043c\u0438 &#8216;g&#8217; \u0438 &#8216;t'(\u0435\u0441\u043b\u0438 \u0443\u0431\u0440\u0430\u0442\u044c \u043f\u0440\u043e\u0431\u0435\u043b \u2014 \u043f\u043e\u043b\u0443\u0447\u0438\u0442\u0441\u044f \u0441\u0438\u043c\u0432\u043e\u043b).<br \/>  \u042d\u0442\u0443 \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u0443 \u0440\u0435\u0448\u0430\u0435\u0442 \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0438\u0439 \u043a\u0443\u0441\u043e\u043a \u0442\u0430\u0441\u043a\u0430:  <\/p>\n<pre><code class=\"javascript\">.pipe(replace('&g t;', '&gt;')) \/\/ remove space between 'g' and 't' letters <\/code><\/pre>\n<p>  \u0422\u0435\u043f\u0435\u0440\u044c \u0441\u0434\u0435\u043b\u0430\u0435\u043c \u0438\u0437 \u043f\u043e\u043b\u0443\u0447\u0438\u0432\u0448\u0435\u0433\u043e\u0441\u044f \u0441\u043f\u0440\u0430\u0439\u0442 \u0438 \u043f\u043e\u043b\u043e\u0436\u0438\u043c \u0432 \u043f\u0430\u043f\u043a\u0443:  <\/p>\n<pre><code class=\"javascript\">.pipe(svgSprite({ \t\tmode: &quot;symbols&quot;, \t\tpreview: false, \t\tselector: &quot;icon-%f&quot;, \t\tsvg: { \t\t\tsymbols: 'symbol_sprite.html' \t\t} \t} )) .pipe(gulp.dest(assetsDir + 'i\/')); <\/code><\/pre>\n<p>  <b>symbol_sprite.html<\/b> \u2014 \u0438 \u0435\u0441\u0442\u044c \u043d\u0430\u0448 \u0441\u043f\u0440\u0430\u0439\u0442. \u0412\u043d\u0443\u0442\u0440\u0438 \u043e\u043d \u0431\u0443\u0434\u0435\u0442 \u0441\u043e\u0434\u0435\u0440\u0436\u0430\u0442\u044c \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u0435(\u0434\u043b\u044f \u043f\u0440\u043e\u0441\u0442\u043e\u0442\u044b \u0443 \u043c\u0435\u043d\u044f \u043f\u0430\u0440\u0430 \u0438\u043a\u043e\u043d\u043e\u043a):   <\/p>\n<pre><code class=\"html\">&lt;svg xmlns=&quot;http:\/\/www.w3.org\/2000\/svg&quot; xmlns:xlink=&quot;http:\/\/www.w3.org\/1999\/xlink&quot; width=&quot;0&quot; height=&quot;0&quot;      style=&quot;position:absolute&quot;&gt;      &lt;symbol id=&quot;icon-burger&quot; viewBox=&quot;0 0 66 64&quot;&gt;         &lt;path fill-rule=&quot;evenodd&quot; clip-rule=&quot;evenodd&quot; d=&quot;M0 0h66v9H0V0zm0 27h66v9H0v-9zm0 27h66v9H0v-9z&quot;\/&gt;     &lt;\/symbol&gt;      &lt;symbol id=&quot;icon-check_round&quot; viewBox=&quot;-0.501 -0.752 18 18&quot;&gt;         &lt;path d=&quot;M8.355 0C3.748 0 0 3.748 0 8.355s3.748 8.355 8.355 8.355 8.355-3.748 8.355-8.355S12.962 0 8.355 0zm0 15.363c-3.865 0-7.01-3.144-7.01-7.01 0-3.864 3.145-7.007 7.01-7.007s7.01 3.144 7.01 7.01-3.146 7.007-7.01 7.007z&quot;\/&gt;         &lt;path d=&quot;M11.018 5.69l-3.9 3.9L5.69 8.165c-.262-.263-.688-.263-.95 0-.264.263-.264.69 0 .952l1.9 1.903c.132.13.304.196.476.196s.344-.066.476-.197l4.376-4.378c.263-.263.263-.69 0-.952s-.69-.262-.952 0z&quot;\/&gt;     &lt;\/symbol&gt;  &lt;\/svg&gt; <\/code><\/pre>\n<p>  <\/p>\n<h4>\u0429\u0435\u043f\u043e\u0442\u043a\u0430 \u0441\u0442\u0438\u043b\u0435\u0439<\/h4>\n<p>  \u0422\u0435\u043f\u0435\u0440\u044c \u043d\u0430\u043c \u043d\u0443\u0436\u043d\u043e \u0441\u0434\u0435\u043b\u0430\u0442\u044c \u0441\u0442\u0438\u043b\u0438 \u0434\u043b\u044f \u043d\u0430\u0448\u0435\u0433\u043e \u0441\u043f\u0440\u0430\u0439\u0442\u0430(\u0432 \u0434\u0430\u043d\u043d\u043e\u043c \u0441\u043b\u0443\u0447\u0430\u0435 \u0444\u0430\u0439\u043b .scss). \u0412 \u043f\u043b\u0430\u0433\u0438\u043d\u0435 gulp-svg-sprites \u043c\u044b \u0437\u0430\u0434\u0430\u0442\u044c \u044d\u0442\u043e\u0442 \u0444\u0430\u0439\u043b, \u043d\u043e \u0432\u043e\u0442 \u043a\u0430\u043a\u0430\u044f \u0434\u043e\u0441\u0430\u0434\u0430 \u2014 \u0435\u0433\u043e \u043d\u0435\u043b\u044c\u0437\u044f \u0441\u0434\u0435\u043b\u0430\u0442\u044c \u043f\u0440\u0438 \u0434\u0430\u043d\u043d\u043e\u0439 \u043d\u0430\u0441\u0442\u0440\u043e\u0439\u043a\u0435:  <\/p>\n<pre><code class=\"javascript\">mode: &quot;symbols&quot; <\/code><\/pre>\n<p>  \u042f \u0440\u0435\u0448\u0438\u043b \u0441\u0434\u0435\u043b\u0430\u0442\u044c \u0434\u043b\u044f \u0441\u043e\u0437\u0434\u0430\u043d\u0438\u044f scss \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u044b\u0439 \u0442\u0430\u0441\u043a. \u0415\u0441\u043b\u0438 \u0432\u044b \u043d\u0430\u0448\u043b\u0438 \u0434\u0440\u0443\u0433\u043e\u0435 \u0440\u0435\u0448\u0435\u043d\u0438\u0435, \u043d\u0430\u043f\u0438\u0448\u0438\u0442\u0435 \u0432 \u043a\u043e\u043c\u043c\u0435\u043d\u0442\u0430\u0440\u0438\u044f\u0445.  <\/p>\n<pre><code class=\"javascript\">\/\/ create sass file for our sprite gulp.task('svgSpriteSass', function () { \treturn gulp.src(assetsDir + 'i\/icons\/*.svg') \t\t.pipe(svgSprite({ \t\t\t\tpreview: false, \t\t\t\tselector: &quot;icon-%f&quot;, \t\t\t\tsvg: { \t\t\t\t\tsprite: 'svg_sprite.html' \t\t\t\t}, \t\t\t\tcssFile: '..\/sass\/_svg_sprite.scss', \t\t\t\ttemplates: { \t\t\t\t\tcss: require(&quot;fs&quot;).readFileSync(assetsDir + 'sass\/_sprite-template.scss', &quot;utf-8&quot;) \t\t\t\t} \t\t\t} \t\t)) \t\t.pipe(gulp.dest(assetsDir + 'i\/')); }); <\/code><\/pre>\n<p>  \u0412 \u0441\u0432\u043e\u0439\u0441\u0442\u0432\u0435 <b>cssFile <\/b> \u043e\u0431\u044a\u044f\u0432\u043b\u044f\u0435\u043c, \u043a\u0443\u0434\u0430 \u043f\u043e\u043b\u043e\u0436\u0438\u0442\u044c \u043d\u0430 scss \u0444\u0430\u0439\u043b(\u043f\u043e\u0442\u043e\u043c \u0438\u043d\u043a\u043b\u0443\u0434\u0438\u043c \u0435\u0433\u043e).<br \/>  \u0412 \u0441\u0432\u043e\u0439\u0441\u0442\u0432\u0435 <b>templates<\/b> \u043e\u0431\u044a\u044f\u0432\u043b\u044f\u0435\u043c, \u0433\u0434\u0435 \u0432\u0437\u044f\u0442\u044c \u0434\u043b\u044f \u043d\u0435\u0433\u043e \u0448\u0430\u0431\u043b\u043e\u043d. \u041a\u043e\u0434 \u043c\u043e\u0435\u0433\u043e \u0448\u0430\u0431\u043b\u043e\u043d\u0430:  <\/p>\n<pre><code class=\"css\">.icon { \tdisplay: inline-block; \theight: 1em; \twidth: 1em; \tfill: inherit; \tstroke: inherit; } {#svg} .{name} { \tfont-size:{height}px; \twidth:({width}\/{height})+em; } {\/svg} <\/code><\/pre>\n<p>  \u041f\u043e\u043b\u0443\u0447\u0430\u0435\u043c _svg_sprite.scss \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u0433\u043e \u0441\u043e\u0434\u0435\u0440\u0436\u0430\u043d\u0438\u044f:  <\/p>\n<pre><code class=\"css\">.icon { \tdisplay: inline-block; \theight: 1em; \twidth: 1em; \tfill: inherit; \tstroke: inherit; }  .icon-burger { \tfont-size:64px; \twidth:(66\/64)+em; }  .icon-check_round { \tfont-size:18px; \twidth:(18\/18)+em; } <\/code><\/pre>\n<p>  \u0421\u043a\u043e\u043c\u043f\u0438\u043b\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u044b\u0439 css \u0431\u0443\u0434\u0435\u0442 \u0442\u0430\u043a\u0438\u043c:  <\/p>\n<pre><code class=\"css\">.icon { \tdisplay: inline-block; \theight: 1em; \twidth: 1em; \tfill: inherit; \tstroke: inherit; }  .icon-burger { \tfont-size: 64px; \twidth: 1.03125em; }  .icon-check_round { \tfont-size: 18px; \twidth: 1em; } <\/code><\/pre>\n<p>  \u041e\u0431\u0440\u0430\u0442\u0438\u0442\u0435 \u0432\u043d\u0438\u043c\u0430\u043d\u0438\u0435, \u0447\u0442\u043e \u0440\u0430\u0437\u043c\u0435\u0440\u044b \u0438\u043a\u043e\u043d\u043e\u043a \u0432\u044b\u0440\u0430\u0436\u0435\u043d\u044b \u0447\u0435\u0440\u0435\u0437 <b>em<\/b>, \u0447\u0442\u043e \u043f\u043e\u0437\u0432\u043e\u043b\u0438\u0442 \u043d\u0430\u043c \u0432 \u0434\u0430\u043b\u044c\u043d\u0435\u0439\u0448\u0435\u043c \u0443\u043f\u0440\u0430\u0432\u043b\u044f\u0442\u044c \u0438\u043c\u0438 \u0447\u0435\u0440\u0435\u0437 font-size.<br \/>  \u0421\u043e\u0441\u0442\u0430\u0432\u043b\u044f\u0435\u043c \u0438\u0442\u043e\u0433\u043e\u0432\u044b\u0439 \u0442\u0430\u0441\u043a, \u0447\u0442\u043e\u0431\u044b \u0437\u0430\u043f\u0443\u0441\u043a\u0430\u0442\u044c \u043e\u0434\u043d\u0443 \u043a\u043e\u043c\u0430\u043d\u0434\u0443:  <\/p>\n<pre><code class=\"javascript\">gulp.task('svgSprite', ['svgSpriteBuild', 'svgSpriteSass']); <\/code><\/pre>\n<p>  <\/p>\n<h4>\u041f\u043e\u0434\u043a\u043b\u044e\u0447\u0430\u0435\u043c \u043d\u0430 \u0441\u0442\u0440\u0430\u043d\u0438\u0446\u0443<\/h4>\n<p>  \u0418\u0442\u0430\u043a \u043c\u044b \u043f\u043e\u043b\u0443\u0447\u0438\u043b\u0438 html-\u0444\u0430\u0439\u043b \u0441 \u0438\u043a\u043e\u043d\u043a\u0430\u043c\u0438 \u0438 scss-\u0444\u0430\u0439\u043b \u0441 \u043e\u0444\u043e\u0440\u043c\u043b\u0435\u043d\u0438\u0435\u043c. \u0414\u0430\u043b\u0435\u0435 \u043f\u043e\u0434\u043a\u043b\u044e\u0447\u0438\u043c \u0444\u0430\u0439\u043b \u043d\u0430 \u0441\u0442\u0440\u0430\u043d\u0438\u0446\u0443, \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044f \u043a\u0435\u0448\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u0435 \u0447\u0435\u0440\u0435\u0437 localStorage. \u042d\u0442\u043e\u0442 \u043f\u0440\u043e\u0446\u0435\u0441\u0441 \u043f\u043e\u0434\u0440\u043e\u0431\u043d\u043e \u043e\u043f\u0438\u0441\u0430\u043d \u0432 \u0441\u0442\u0430\u0442\u044c\u0435 <a href=\"http:\/\/osvaldas.info\/caching-svg-sprite-in-localstorage\">Caching SVG Sprite in localStorage<\/a>.<br \/>  \u041f\u043e\u0434\u043a\u043b\u044e\u0447\u0430\u0435\u043c js-\u0444\u0430\u0439\u043b \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u0433\u043e \u0441\u043e\u0434\u0435\u0440\u0436\u0430\u043d\u0438\u044f:  <\/p>\n<pre><code class=\"javascript\">;( function( window, document ) { \t'use strict';  \tvar file     = 'i\/symbol_sprite.html', \t\trevision = 1;  \tif( !document.createElementNS || !document.createElementNS( 'http:\/\/www.w3.org\/2000\/svg', 'svg' ).createSVGRect ) \t\treturn true;  \tvar isLocalStorage = 'localStorage' in window && window[ 'localStorage' ] !== null, \t\trequest, \t\tdata, \t\tinsertIT = function() \t\t{ \t\t\tdocument.body.insertAdjacentHTML( 'afterbegin', data ); \t\t}, \t\tinsert = function() \t\t{ \t\t\tif( document.body ) insertIT(); \t\t\telse document.addEventListener( 'DOMContentLoaded', insertIT ); \t\t};  \tif( isLocalStorage && localStorage.getItem( 'inlineSVGrev' ) == revision ) \t{ \t\tdata = localStorage.getItem( 'inlineSVGdata' ); \t\tif( data ) \t\t{ \t\t\tinsert(); \t\t\treturn true; \t\t} \t}  \ttry \t{ \t\trequest = new XMLHttpRequest(); \t\trequest.open( 'GET', file, true ); \t\trequest.onload = function() \t\t{ \t\t\tif( request.status &gt;= 200 && request.status &lt; 400 ) \t\t\t{ \t\t\t\tdata = request.responseText; \t\t\t\tinsert(); \t\t\t\tif( isLocalStorage ) \t\t\t\t{ \t\t\t\t\tlocalStorage.setItem( 'inlineSVGdata',  data ); \t\t\t\t\tlocalStorage.setItem( 'inlineSVGrev',   revision ); \t\t\t\t} \t\t\t} \t\t} \t\trequest.send(); \t} \tcatch( e ){}  }( window, document ) ); <\/code><\/pre>\n<p>  \u0412\u0441\u0435, \u043c\u044b \u043f\u043e\u0434\u043a\u043b\u044e\u0447\u0438\u043b\u0438 \u043d\u0430\u0448 \u0444\u0430\u0439\u043b \u043d\u0430 \u0441\u0442\u0440\u0430\u043d\u0438\u0446\u0443, \u043f\u043e\u0441\u043b\u0435 \u043f\u0435\u0440\u0432\u043e\u0439 \u0437\u0430\u0433\u0440\u0443\u0437\u043a\u0438 \u043e\u043d \u043a\u0435\u0448\u0438\u0440\u0443\u0435\u0442\u0441\u044f.<br \/>  \u0418\u043a\u043e\u043d\u043a\u0438 \u044f \u0432\u0441\u0442\u0440\u0430\u0438\u0432\u0430\u044e \u0447\u0435\u0440\u0435\u0437 \u043c\u0438\u043a\u0441\u0438\u043d jade, \u0442.\u043a. \u044d\u0442\u043e \u0431\u044b\u0441\u0442\u0440\u043e \u0438 \u0443\u0434\u043e\u0431\u043d\u043e:  <\/p>\n<pre><code class=\"javascript\">mixin icon(name,mod) \t- mod = mod || '' \tsvg(class=&quot;icon icon-&quot; + name + ' ' + mod) \t\tuse(xlink:href=&quot;#icon-&quot; + name) <\/code><\/pre>\n<p>  \u0422\u0435\u043f\u0435\u0440\u044c, \u0447\u0442\u043e\u0431\u044b \u0432\u0441\u0442\u0440\u043e\u0438\u0442\u044c \u0438\u043a\u043e\u043d\u043a\u0443 \u0432\u044b\u0437\u044b\u0432\u0430\u0435\u043c \u043c\u0438\u043a\u0441\u0438\u043d \u0441 \u0435\u0451 \u0438\u043c\u0435\u043d\u0435\u043c:  <\/p>\n<pre><code class=\"javascript\">+icon('check_round','red_mod') +icon('burger','green_mod') <\/code><\/pre>\n<p>  \u0420\u0435\u0437\u0443\u043b\u044c\u0442\u0438\u0440\u0443\u044e\u0449\u0438\u0439 html:  <\/p>\n<pre><code class=\"html\">&lt;svg class=&quot;icon icon-check_round red_mod&quot;&gt;     &lt;use xlink:href=&quot;#icon-check_round&quot;&gt;&lt;\/use&gt; &lt;\/svg&gt; &lt;svg class=&quot;icon icon-burger green_mod&quot;&gt;     &lt;use xlink:href=&quot;#icon-burger&quot;&gt;&lt;\/use&gt; &lt;\/svg&gt; <\/code><\/pre>\n<p>  \u041e\u0442\u043a\u0440\u044b\u0432\u0430\u0435\u043c \u0441\u0442\u0440\u0430\u043d\u0438\u0446\u0443 \u0432 \u0431\u0440\u0430\u0443\u0437\u0435\u0440\u0435:<\/p>\n<p>  <img decoding=\"async\" src=\"https:\/\/habrastorage.org\/files\/86f\/e46\/37d\/86fe4637d9814b3d8199b0007bfede61.png\"\/><\/p>\n<p>  \u041f\u043e\u043a\u0430 \u0440\u0430\u0437\u043c\u0435\u0440\u044b \u0438\u043a\u043e\u043d\u043e\u043a \u0432 \u043d\u0430\u0442\u0443\u0440\u0430\u043b\u044c\u043d\u0443\u044e \u0432\u0435\u043b\u0438\u0447\u0438\u043d\u0443 \u0438 \u0438\u043c\u0435\u044e\u0442 \u0441\u0442\u0430\u043d\u0434\u0430\u0440\u0442\u043d\u044b\u0439 \u0446\u0432\u0435\u0442. \u0418\u0437\u043c\u0435\u043d\u0438\u043c \u044d\u0442\u043e(\u043d\u0435 \u0432 \u0441\u0433\u0435\u043d\u0435\u0440\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u043e\u043c \u0444\u0430\u0439\u043b\u0435, \u0430 \u0432 \u0433\u043b\u0430\u0432\u043d\u043e\u043c):  <\/p>\n<pre><code class=\"css\">.icon-burger { \tfont-size:3rem; \t&.green_mod { \t\tfill:green; \t}  } .icon-check_round { \tfont-size:3rem; \t&.red_mod { \t\tfill: red; \t} } <\/code><\/pre>\n<p>  \u0420\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442:<br \/>  <img decoding=\"async\" src=\"https:\/\/habrastorage.org\/files\/e04\/e2b\/4a0\/e04e2b4a09524a4fac31ce4094629971.png\"\/><br \/>  \u0412\u043e\u0442 \u0438 \u0432\u0441\u0435, \u043c\u044b \u043f\u043e\u043b\u0443\u0447\u0438\u043b\u0438 \u0440\u0430\u0431\u043e\u0447\u0443\u044e \u0441\u0438\u0441\u0442\u0435\u043c\u0443 \u043f\u043e\u0434\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u044f \u0438\u043a\u043e\u043d\u043e\u043a \u0447\u0435\u0440\u0435\u0437 \u0441\u043f\u0440\u0430\u0439\u0442\u044b, \u043d\u043e \u0435\u0441\u0442\u044c \u0435\u0449\u0435 \u043e\u0434\u0438\u043d \u043c\u043e\u043c\u0435\u043d\u0442.<\/p>\n<h4>\u0420\u0430\u0437\u043c\u044b\u0442\u0438\u0435<\/h4>\n<p>  \u041a \u0441\u043e\u0436\u0430\u043b\u0435\u043d\u0438\u044e, \u043d\u0435 \u0432\u0441\u0435 \u0434\u0438\u0437\u0430\u0439\u043d\u0435\u0440\u044b \u0434\u0435\u043b\u0430\u044e\u0442 \u0438\u043a\u043e\u043d\u043a\u0438 \u043f\u043e \u043f\u0438\u043a\u0441\u0435\u043b\u044c\u043d\u043e\u0439 \u0441\u0435\u0442\u043a\u0435. \u0412 \u044d\u0442\u043e\u043c \u0441\u043b\u0443\u0447\u0430\u0435 \u0438\u043a\u043e\u043d\u043a\u0438 \u0431\u0443\u0434\u0443\u0442 \u00ab\u0440\u0430\u0437\u043c\u044b\u0432\u0430\u0442\u044c\u0441\u044f\u00bb. \u0415\u0441\u043b\u0438 \u0432\u044b \u044d\u043a\u0441\u043f\u043e\u0440\u0442\u0438\u0440\u0443\u0435\u0442\u0435 \u0438\u043a\u043e\u043d\u043a\u0438 \u0438\u0437 \u0438\u043b\u043b\u044e\u0441\u0442\u0440\u0430\u0442\u043e\u0440\u0430 \u0432\u0430\u043c \u043d\u0443\u0436\u043d\u043e \u0432\u043a\u043b\u044e\u0447\u0438\u0442\u044c \u043f\u0438\u043a\u0441\u0435\u043b\u044c\u043d\u0443\u044e \u0441\u0435\u0442\u043a\u0443 \u0438 \u043f\u043e\u0434\u043e\u0433\u043d\u0430\u0442\u044c \u0440\u0430\u0437\u043c\u0435\u0440 \u0438 \u0440\u0430\u0441\u043f\u043e\u043b\u043e\u0436\u0435\u043d\u0438\u0435 \u0438\u043a\u043e\u043d\u043a\u0438 \u043f\u043e\u0434 \u043f\u0438\u043a\u0441\u0435\u043b\u044c\u043d\u0443\u044e \u0441\u0435\u0442\u043a\u0443. \u0415\u0441\u043b\u0438 \u0432\u044b \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442\u0435 \u0432 \u0433\u043e\u0442\u043e\u0432\u044b\u043c\u0438 svg-\u0444\u0430\u0439\u043b\u0430\u043c\u0438 \u2014 \u0432\u043e\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0439\u0442\u0435\u0441\u044c \u0441\u0435\u0440\u0432\u0438\u0441\u043e\u043c <a href=\"https:\/\/icomoon.io\/app\/\">iconmoon<\/a> \u0434\u043b\u044f \u0438\u0445 \u043f\u0440\u0430\u0432\u0438\u043b\u044c\u043d\u043e\u0433\u043e \u0432\u044b\u0440\u0430\u0432\u043d\u0438\u0432\u0430\u043d\u0438\u044f.<\/p>\n<p>  \u041e\u0441\u043e\u0431\u0443\u044e \u0431\u043b\u0430\u0433\u043e\u0434\u0430\u0440\u043d\u043e\u0441\u0442\u044c \u0432\u044b\u0440\u0430\u0436\u0430\u044e <a href=\"https:\/\/twitter.com\/akella\">@akella<\/a>, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u043f\u043e\u043c\u043e\u0433 \u043c\u043d\u0435 \u0432 \u043d\u0430\u043f\u0438\u0441\u0430\u043d\u0438\u0438 \u0434\u0430\u043d\u043d\u043e\u0433\u043e \u0440\u0435\u0448\u0435\u043d\u0438\u044f.               <\/p>\n<div class=\"clear\"><\/div>\n<p> \u0441\u0441\u044b\u043b\u043a\u0430 \u043d\u0430 \u043e\u0440\u0438\u0433\u0438\u043d\u0430\u043b \u0441\u0442\u0430\u0442\u044c\u0438 <a href=\"http:\/\/habrahabr.ru\/post\/272505\/\"> http:\/\/habrahabr.ru\/post\/272505\/<\/a><\/p>\n","protected":false},"excerpt":{"rendered":"<p>       \u041f\u0440\u0438\u0432\u0435\u0442, \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a!<br \/>  \u041f\u0440\u0438 \u0432\u0435\u0440\u0441\u0442\u043a\u0435 \u043c\u0430\u043a\u0435\u0442\u0430 \u0438\u0437 PSD \u0447\u0430\u0441\u0442\u043e \u0438\u043a\u043e\u043d\u043a\u0438 \u0432\u0441\u0442\u0430\u0432\u043b\u0435\u043d\u044b \u0432 \u0444\u043e\u0440\u043c\u0430\u0442\u0435 SVG. \u0410 \u0435\u0441\u043b\u0438 \u043d\u0435\u0442 \u2014 \u043f\u0440\u043e\u0448\u0443 \u0438\u0445 \u0443 \u0434\u0438\u0437\u0430\u0439\u043d\u0435\u0440\u0430. \u0420\u0430\u043d\u0435\u0435 \u044f \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043b \u0438\u043a\u043e\u043d\u043e\u0447\u043d\u044b\u0435 \u0448\u0440\u0438\u0444\u0442\u044b, \u043d\u043e \u043d\u0435\u0434\u0430\u0432\u043d\u043e \u0443\u0432\u0438\u0434\u0435\u043b \u043f\u0440\u0435\u0438\u043c\u0443\u0449\u0435\u0441\u0442\u0432\u0430 \u0441\u043f\u0440\u0430\u0439\u0442\u043e\u0432 \u0438 \u0440\u0435\u0448\u0438\u043b \u043f\u043e\u043f\u0440\u043e\u0431\u043e\u0432\u0430\u0442\u044c <s>\u0441 \u043d\u0438\u043c\u0438 \u043f\u043e\u0438\u0433\u0440\u0430\u0442\u044c\u0441\u044f<\/s> \u0432\u043d\u0435\u0434\u0440\u0438\u0442\u044c \u0438\u0445 \u0432 \u043f\u0440\u043e\u0446\u0435\u0441\u0441 \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u043a\u0438. \u041c\u043d\u0435 \u043d\u0440\u0430\u0432\u044f\u0442\u0441\u044f \u0438\u043a\u043e\u043d\u043e\u0447\u043d\u044b\u0435 \u0448\u0440\u0438\u0444\u0442\u044b, \u043d\u043e \u043e\u043d\u0438 \u0438\u043c\u0435\u044e\u0442 \u0440\u044f\u0434 \u043d\u0435\u0434\u043e\u0441\u0442\u0430\u0442\u043a\u043e\u0432(\u043d\u0430 \u044d\u0442\u0443 \u0442\u0435\u043c\u0443 \u043f\u043e\u0447\u0438\u0442\u0430\u0439\u0442\u0435 <a href=\"https:\/\/css-tricks.com\/icon-fonts-vs-svg\/\">CSSTricks<\/a>). \u042d\u043a\u0441\u043f\u0435\u0440\u0438\u043c\u0435\u043d\u0442 \u0443\u0434\u0430\u043b\u0441\u044f, \u0438 \u0432\u043e\u0442 \u043a\u0430\u043a \u044f \u043e\u0440\u0433\u0430\u043d\u0438\u0437\u043e\u0432\u0430\u043b \u0441\u0438\u0441\u0442\u0435\u043c\u0443.  <\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[],"tags":[],"class_list":["post-269746","post","type-post","status-publish","format-standard","hentry"],"_links":{"self":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/269746","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=269746"}],"version-history":[{"count":0,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/269746\/revisions"}],"wp:attachment":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=269746"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=269746"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=269746"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}