{"id":275132,"date":"2016-02-29T10:46:02","date_gmt":"2016-02-29T07:46:02","guid":{"rendered":"http:\/\/savepearlharbor.com\/?p=275132"},"modified":"-0001-11-30T00:00:00","modified_gmt":"-0001-11-29T21:00:00","slug":"","status":"publish","type":"post","link":"https:\/\/savepearlharbor.com\/?p=275132","title":{"rendered":"\u041f\u0438\u043b\u0438\u043c \u0432\u0435\u0431-\u0434\u0435\u043c\u043a\u0443 \u2014 Wavescroll"},"content":{"rendered":"<p>       \u0412 \u044d\u0442\u043e\u0439 \u0441\u0442\u0430\u0442\u044c\u0435 \u044f \u043f\u043e\u0441\u0442\u0430\u0440\u0430\u044e\u0441\u044c \u0434\u043e\u0445\u043e\u0434\u0447\u0438\u0432\u043e \u0440\u0430\u0441\u0441\u043a\u0430\u0437\u0430\u0442\u044c \u043e \u043f\u0440\u043e\u0446\u0435\u0441\u0441\u0435 \u0441\u043e\u0437\u0434\u0430\u043d\u0438\u044f <a href=\"http:\/\/codepen.io\/suez\/full\/wMOVXz\">\u0434\u0435\u043c\u043a\u0438 Wavescroll<\/a>.<\/p>\n<p>  <img decoding=\"async\" src=\"http:\/\/i.imgur.com\/MXoOiZM.jpg\" alt=\"image\"\/><br \/>  <a name=\"habracut\"><\/a>  <\/p>\n<h4>\u041e \u043a\u043e\u0434\u0435 \u0432 \u0441\u0442\u0430\u0442\u044c\u0435<\/h4>\n<p>  \u0426\u0435\u043b\u044c \u044d\u0442\u043e\u0439 \u0441\u0442\u0430\u0442\u044c\u0438, \u043f\u043e\u043f\u044b\u0442\u0430\u0442\u044c\u0441\u044f \u043d\u0430\u0443\u0447\u0438\u0442\u044c \u043b\u044e\u0434\u0435\u0439 \u0440\u0435\u0430\u043b\u0438\u0437\u043e\u0432\u044b\u0432\u0430\u0442\u044c \u0440\u0430\u0437\u043b\u0438\u0447\u043d\u044b\u0435 \u043d\u0435\u0442\u0440\u0438\u0432\u0438\u0430\u043b\u044c\u043d\u044b\u0435 \u044d\u0444\u0444\u0435\u043a\u0442\u044b, \u043d\u0435 \u043f\u043e\u043b\u0430\u0433\u0430\u044f\u0441\u044c \u0432\u0441\u044e \u0436\u0438\u0437\u043d\u044c \u043d\u0430 \u0433\u043e\u0442\u043e\u0432\u044b\u0435 \u043f\u043b\u0430\u0433\u0438\u043d\u044b \u0438 \u043f\u043e\u0434\u043e\u0431\u043d\u044b\u0435 \u0440\u0435\u0448\u0435\u043d\u0438\u044f \u0434\u043b\u044f \u043a\u0430\u0436\u0434\u043e\u0433\u043e \u0447\u0438\u0445\u0430. \u041a\u043e\u0434 \u0432 \u0434\u0435\u043c\u043e (\u043a\u0430\u043a \u0438 \u0441\u0430\u043c\u0430 \u0441\u0442\u0430\u0442\u044c\u044f) \u043d\u0430\u043f\u0438\u0441\u0430\u043d\u044b \u043f\u0440\u044f\u043c\u043e\u043b\u0438\u043d\u0435\u0439\u043d\u043e \u0438 \u0432\u0435\u0441\u044c\u043c\u0430 \u0434\u043e\u0445\u043e\u0434\u0447\u0438\u0432\u043e (\u043d\u0430\u0434\u0435\u044e\u0441\u044c), \u0431\u0435\u0437 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u044f \u043c\u043d\u043e\u0436\u0435\u0441\u0442\u0432\u0430 \u043b\u0438\u0448\u043d\u0438\u0445 \u0432\u0435\u0449\u0435\u0439, \u043a\u043e\u0442\u043e\u0440\u044b\u043c\u0438 \u043d\u044b\u043d\u0447\u0435 \u043f\u0435\u0440\u0435\u043f\u043e\u043b\u043d\u0435\u043d\u044b \u0432\u0441\u0435 \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u044b\u0435 \u043e\u0431\u0443\u0447\u0430\u043b\u043a\u0438. \u0417\u0434\u0435\u0441\u044c \u043d\u0435\u0442\u0443 ES6, \u0432\u0435\u0431\u043f\u0430\u043a\u0430, \u0440\u0435\u0430\u043a\u0442\u0430, \u043c\u043e\u0434\u0443\u043b\u044c\u043d\u044b\u0445 \u0441\u0438\u0441\u0442\u0435\u043c \u0438 \u043f\u0440\u043e\u0447\u0438\u0445 \u0432\u0435\u0449\u0435\u0439. \u0412\u0430\u043c \u043d\u0435 \u043f\u043e\u0442\u0440\u0435\u0431\u0443\u0435\u0442\u0441\u044f \u0441\u0438\u0434\u0435\u0442\u044c 5-15 \u043c\u0438\u043d\u0443\u0442 \u0432 \u043a\u043e\u043c\u0430\u043d\u0434\u043d\u043e\u0439 \u0441\u0442\u0440\u043e\u043a\u0435, \u0443\u0441\u0442\u0430\u043d\u0430\u0432\u043b\u0438\u0432\u0430\u044f \u0440\u0430\u0437\u043b\u0438\u0447\u043d\u044b\u0435 \u0437\u0430\u0432\u0438\u0441\u0438\u043c\u043e\u0441\u0442\u0438 \u0434\u043b\u044f \u043e\u043a\u0440\u0443\u0436\u0435\u043d\u0438\u044f, \u0434\u0430\u0431\u044b \u043f\u043e\u0442\u043e\u043c \u043d\u0430\u043a\u043e\u043d\u0435\u0446-\u0442\u043e \u0432\u044b\u0432\u0435\u0441\u0442\u0438 \u0437\u0430\u0432\u0435\u0442\u043d\u044b\u0439 Hello World \u043d\u0430 \u044d\u043a\u0440\u0430\u043d. \u041c\u044b \u0431\u0443\u0434\u0435\u043c \u043f\u0438\u0441\u0430\u0442\u044c \u00ab\u0442\u043e\u043f\u043e\u0440\u043d\u044b\u0439\u00bb \u043a\u043e\u0434, \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c jQuery \u043f\u043e\u0442\u043e\u043c\u0443-\u0447\u0442\u043e \u043e\u043d \u043f\u043e\u043d\u044f\u0442\u0435\u043d \u043f\u043e\u0447\u0442\u0438 \u043b\u044e\u0431\u043e\u043c\u0443 \u0447\u0435\u043b\u043e\u0432\u0435\u043a\u0443, \u043a\u0442\u043e \u0445\u043e\u0442\u044c \u0440\u0430\u0437 \u0440\u0430\u0431\u043e\u0442\u0430\u043b \u0441 javascript, \u0438 \u0432 \u043a\u043e\u043d\u0446\u0435 \u043f\u043e\u043b\u0443\u0447\u0438\u043c \u043d\u0435\u0447\u0442\u043e, \u0447\u0442\u043e \u043c\u043e\u0436\u043d\u043e \u043f\u043e\u0449\u0443\u043f\u0430\u0442\u044c.<\/p>\n<p>  \u0412\u0441\u0435 \u0434\u0435\u043c\u043a\u0438 \u044f \u0441\u043e\u0437\u0434\u0430\u044e \u043d\u0430 codepen&#8217;\u0435, \u0433\u0434\u0435 \u0440\u0430\u0437\u043b\u0438\u0447\u043d\u044b\u0435 \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0438 \u0438 \u043f\u0440\u0435\u043f\u0440\u043e\u0446\u0435\u0441\u0441\u043e\u0440\u044b \u043f\u043e\u0434\u043a\u043b\u044e\u0447\u0430\u044e\u0442\u0441\u044f \u043f\u0430\u0440\u043e\u0439 \u043a\u043b\u0438\u043a\u043e\u0432 \u0438 \u0432\u0430\u043c \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e \u0442\u043e\u043b\u044c\u043a\u043e \u043b\u0438\u0448\u044c \u043f\u0438\u0441\u0430\u0442\u044c \u043a\u043e\u0434.<\/p>\n<h4>\u041f\u0440\u0435\u0434\u044b\u0441\u0442\u043e\u0440\u0438\u044f<\/h4>\n<p>  \u041d\u0430\u0447\u0430\u043b\u043e\u0441\u044c \u0432\u0441\u0435 \u0441 \u0442\u043e\u0433\u043e, \u0447\u0442\u043e \u043d\u0430 \u043f\u0440\u043e\u0441\u0442\u043e\u0440\u0430\u0445 \u0438\u043d\u0442\u0435\u0440\u043d\u0435\u0442\u0430 \u044f \u043d\u0430\u0442\u043a\u043d\u0443\u043b\u0441\u044f \u043d\u0430 \u043f\u0440\u0435\u043a\u0440\u0430\u0441\u043d\u044b\u0439 \u0441\u0430\u0439\u0442 jetlag.photos, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u043f\u043e\u0440\u0430\u0437\u0438\u043b \u043c\u0435\u043d\u044f \u0441\u0432\u043e\u0438\u043c \u044d\u0444\u0444\u0435\u043a\u0442\u043e\u043c \u0441\u0432\u0430\u0439\u043f\u0430 \u0431\u044d\u043a\u0433\u0440\u0430\u0443\u043d\u0434\u0430 (\u0437\u0430\u0436\u043c\u0438\u0442\u0435 \u043b\u0435\u0444\u0442\u043a\u043b\u0438\u043a \u043c\u044b\u0448\u0438 \u0433\u0434\u0435 \u0443\u0433\u043e\u0434\u043d\u043e \u0438 \u0442\u044f\u043d\u0438\u0442\u0435). \u0421\u0440\u0430\u0437\u0443 \u0436\u0435 \u043f\u043e\u044f\u0432\u0438\u043b\u043e\u0441\u044c \u0436\u0435\u043b\u0430\u043d\u0438\u0435 \u0440\u0435\u0430\u043b\u0438\u0437\u043e\u0432\u0430\u0442\u044c \u043a\u043b\u043e\u043d \u0431\u0435\u0437 \u043f\u043e\u0434\u0433\u043b\u044f\u0434\u044b\u0432\u0430\u043d\u0438\u0439 \u00ab\u043f\u043e\u0434 \u043a\u0430\u043f\u043e\u0442\u00bb. \u041a\u0430\u043a \u0443\u0436\u0435 \u043f\u043e\u0442\u043e\u043c \u0432\u044b\u044f\u0441\u043d\u0438\u043b\u043e\u0441\u044c, \u0434\u0430\u0436\u0435 \u043f\u0440\u0438 \u0436\u0435\u043b\u0430\u043d\u0438\u0438 \u044f \u0431\u044b \u043d\u0435 \u0441\u043c\u043e\u0433 \u0438\u0437\u0432\u043b\u0435\u0447\u044c \u043d\u0438\u043a\u0430\u043a\u043e\u0439 \u043f\u043e\u043b\u0435\u0437\u043d\u043e\u0439 \u0438\u043d\u0444\u043e\u0440\u043c\u0430\u0446\u0438\u0438 \u0438\u0437 devTools, \u0438\u0431\u043e \u0432\u0441\u0435 \u0431\u044b\u043b\u043e \u0440\u0435\u0430\u043b\u0438\u0437\u043e\u0432\u0430\u043d\u043e \u043d\u0430 canvas&#8217;\u0435. \u0410 \u043a\u043e\u043f\u0430\u0442\u044c\u0441\u044f \u0432 \u0441\u0436\u0430\u0442\u043e\u043c&#038;\u0430\u0433\u043b\u0438\u0444\u0438\u0446\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u043e\u043c \u043a\u043e\u0434\u0435 \u043a\u0430\u043d\u0432\u0430\u0441\u0430 \u044d\u0442\u043e \u0442\u043e \u0435\u0449\u0435 \u0438\u0437\u0432\u0440\u0430\u0449\u0435\u043d\u0438\u0435. \u0422\u0430\u043a \u0447\u0442\u043e \u0434\u0435\u043c\u043a\u0443 \u044f \u043d\u0430\u0447\u0430\u043b \u043f\u0438\u043b\u0438\u0442\u044c, \u0440\u0443\u043a\u043e\u0432\u043e\u0434\u0441\u0442\u0432\u0443\u044f\u0441\u044c \u043b\u0438\u0448\u044c \u0442\u0435\u043c, \u0447\u0442\u043e \u0432\u0438\u0436\u0443 \u043d\u0430 \u044d\u043a\u0440\u0430\u043d\u0435, \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044f \u0441\u0442\u0430\u043d\u0434\u0430\u0440\u0442\u043d\u0443\u044e \u0441\u0432\u044f\u0437\u043a\u0443 html+css+js (\u0441 \u043a\u0430\u043d\u0432\u0430\u0441\u043e\u043c \u044f \u0432\u0441\u0435 \u0440\u0430\u0432\u043d\u043e \u043d\u0435 \u043e\u0441\u043e\u0431\u043e \u0434\u0440\u0443\u0436\u0443).<\/p>\n<h4>\u0421\u0442\u0430\u0440\u0442\u0443\u0435\u043c<\/h4>\n<p>  \u0414\u043b\u044f \u043d\u0430\u0447\u0430\u043b\u0430 \u043d\u0430\u043c \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e \u0441\u043e\u0437\u0434\u0430\u0442\u044c \u0444\u0443\u043b\u043b\u0441\u043a\u0440\u0438\u043d-\u043a\u043e\u043d\u0442\u0435\u0439\u043d\u0435\u0440, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0431\u0443\u0434\u0435\u0442 \u0441\u043e\u0434\u0435\u0440\u0436\u0430\u0442\u044c \u0432\u043d\u0443\u0442\u0440\u0438 \u0431\u043b\u043e\u043a\u0438 \u0441 \u0431\u044d\u043a\u0433\u0440\u0430\u0443\u043d\u0434\u0430\u043c\u0438.<\/p>\n<pre><code class=\"html\">&lt;div class=&quot;ws-pages&quot;&gt;   &lt;div class=&quot;ws-bgs&quot;&gt;     &lt;div class=&quot;ws-bg&quot;&gt;&lt;\/div&gt;     &lt;div class=&quot;ws-bg&quot;&gt;&lt;\/div&gt;     &lt;div class=&quot;ws-bg&quot;&gt;&lt;\/div&gt;     &lt;div class=&quot;ws-bg&quot;&gt;&lt;\/div&gt;     &lt;div class=&quot;ws-bg&quot;&gt;&lt;\/div&gt;   &lt;\/div&gt; &lt;\/div&gt; <\/code><\/pre>\n<p>  \u0412\u0441\u0435 \u0431\u044d\u043a\u0433\u0440\u0430\u0443\u043d\u0434\u044b \u0432\u043b\u043e\u0436\u0435\u043d\u044b \u0432 \u0434\u043e\u043f\u043e\u043b\u043d\u0438\u0442\u0435\u043b\u044c\u043d\u044b\u0439 \u0431\u043b\u043e\u043a, \u0442\u0430\u043a \u043a\u0430\u043a \u043f\u043e\u0442\u043e\u043c \u0443 \u043d\u0430\u0441 \u0435\u0449\u0435 \u043f\u043e\u044f\u0432\u0438\u0442\u0441\u044f \u0431\u043b\u043e\u043a \u0434\u043b\u044f \u0442\u0435\u043a\u0441\u0442\u043e\u0432. \u0422\u0435\u043f\u0435\u0440\u044c \u0441\u0442\u0438\u043b\u0438\u0437\u0443\u0435\u043c \u0438\u0445:<\/p>\n<pre><code class=\"css\">.ws {    &-pages {     overflow: hidden;     position: relative;     height: 100vh; \/\/ \u043e\u0441\u043d\u043e\u0432\u043d\u043e\u0439 \u043a\u043e\u043d\u0442\u0435\u0439\u043d\u0435\u0440 \u0431\u0443\u0434\u0435\u0442 \u0437\u0430\u043d\u0438\u043c\u0430\u0442\u044c 100% \u0432\u044b\u0441\u043e\u0442\u044b \u044d\u043a\u0440\u0430\u043d\u0430   }    &-bgs {     position: relative;     height: 100%;   }    &-bg {     height: 100%;     background-size: cover;     background-position: center center;      \/\/ \u043e\u0447\u0438\u0449\u0430\u0435\u043c \u043f\u043e\u0442\u043e\u043a, \u0434\u043b\u044f \u0447\u0430\u0441\u0442\u0435\u0439, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u0431\u0443\u0434\u0443\u0442 \u0432\u0441\u0442\u0430\u0432\u043b\u0435\u043d\u044b \u043f\u043e\u0437\u0436\u0435     &:after {       content: &quot;&quot;;       display: table;       clear: both;     } } <\/code><\/pre>\n<p>  <\/p>\n<div class=\"spoiler\"><b class=\"spoiler_title\">\u041e CSS<\/b><\/p>\n<div class=\"spoiler_text\">\u041a\u0430\u043a \u0432\u044b \u0443\u0436\u0435 \u0437\u0430\u043c\u0435\u0442\u0438\u043b\u0438, \u044f \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044e \u043f\u0440\u0435\u043f\u0440\u043e\u0446\u0435\u0441\u0441\u043e\u0440. \u0412 \u0434\u0430\u043d\u043d\u043e\u043c \u0441\u043b\u0443\u0447\u0430\u0435 \u044d\u0442\u043e SASS \u0441 \u0441\u0438\u043d\u0442\u0430\u043a\u0441\u0438\u0441\u043e\u043c SCSS.  <\/div>\n<\/div>\n<p>  \u0422\u0435\u043f\u0435\u0440\u044c \u043d\u0430\u043c \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e \u0441\u043e\u0437\u0434\u0430\u0442\u044c \u0447\u0430\u0441\u0442\u0438 \u0431\u044d\u043a\u0433\u0440\u0430\u0443\u043d\u0434\u043e\u0432, \u0434\u043e\u0431\u0430\u0432\u0438\u0442\u044c \u0438\u0445 \u0432 \u0441\u043e\u043e\u0442\u0432\u0435\u0442\u0441\u0442\u0432\u0443\u044e\u0449\u0438\u0435 \u0431\u043b\u043e\u043a\u0438 \u0438 \u0441\u0442\u0438\u043b\u0438\u0437\u043e\u0432\u0430\u0442\u044c. \u041d\u0430\u0448\u0430 \u0437\u0430\u0434\u0430\u0447\u0430 \u0441\u0434\u0435\u043b\u0430\u0442\u044c \u0442\u0430\u043a, \u0447\u0442\u043e\u0431\u044b \u0432\u0441\u0435 \u043a\u0443\u0441\u043e\u0447\u043a\u0438 \u0432 \u0438\u0442\u043e\u0433\u0435 \u0441\u043c\u043e\u0442\u0440\u0435\u043b\u0438\u0441\u044c \u043a\u0430\u043a \u0435\u0434\u0438\u043d\u044b\u0439 \u0431\u043b\u043e\u043a, \u0431\u044d\u043a\u0433\u0440\u0430\u0443\u043d\u0434 \u043a\u043e\u0442\u043e\u0440\u043e\u0433\u043e \u0440\u0430\u0441\u0442\u044f\u043d\u0443\u0442 \u0441 \u043f\u043e\u043c\u043e\u0449\u044c\u044e background-size: cover \u0438 \u043e\u0442\u0446\u0435\u043d\u0442\u0440\u043e\u0432\u0430\u043d. \u0414\u043b\u044f \u044d\u0442\u043e\u0433\u043e \u0432\u043d\u0443\u0442\u0440\u044c \u043a\u0430\u0436\u0434\u043e\u0439 \u0447\u0430\u0441\u0442\u0438 \u0431\u0443\u0434\u0435\u0442 \u0434\u043e\u0431\u0430\u0432\u043b\u0435\u043d \u0434\u043e\u043f\u043e\u043b\u043d\u0438\u0442\u0435\u043b\u044c\u043d\u044b\u0439 \u0431\u043b\u043e\u043a, \u043a\u043e\u0442\u043e\u0440\u043e\u043c\u0443 \u0438 \u0431\u0443\u0434\u0435\u0442 \u0432\u044b\u0441\u0442\u0430\u0432\u043b\u044f\u0442\u044c\u0441\u044f \u0444\u043e\u043d\u043e\u0432\u0430\u044f \u043a\u0430\u0440\u0442\u0438\u043d\u043a\u0430. \u041a\u0430\u0436\u0434\u044b\u0439 \u0432\u043d\u0443\u0442\u0440\u0435\u043d\u043d\u0438\u0439 \u0431\u043b\u043e\u043a \u0431\u0443\u0434\u0435\u0442 \u0437\u0430\u043d\u0438\u043c\u0430\u0442\u044c 100% \u0448\u0438\u0440\u0438\u043d\u044b \u044d\u043a\u0440\u0430\u043d\u0430 \u0438 \u0441\u043c\u0435\u0449\u0430\u0442\u044c\u0441\u044f \u0432\u043b\u0435\u0432\u043e \u0441 \u043a\u0430\u0436\u0434\u044b\u043c \u0448\u0430\u0433\u043e\u043c, \u0447\u0442\u043e\u0431\u044b \u0432 \u0438\u0442\u043e\u0433\u0435 \u043f\u043e\u043b\u0443\u0447\u0438\u043b\u0430\u0441\u044c \u0446\u0435\u043b\u044c\u043d\u0430\u044f \u043a\u0430\u0440\u0442\u0438\u043d\u043a\u0430.<\/p>\n<pre><code class=\"css\">.ws-bg {    &__part {     overflow: hidden; \/\/ \u043a\u0430\u0436\u0434\u0430\u044f \u0447\u0430\u0441\u0442\u044c \u0434\u043e\u043b\u0436\u043d\u0430 \u043f\u043e\u043a\u0430\u0437\u044b\u0432\u0430\u0442\u044c \u0442\u043e\u043b\u044c\u043a\u043e \u043a\u043e\u043d\u0442\u0435\u043d\u0442 \u0432 \u0440\u0430\u043c\u043a\u0430\u0445 \u0441\u0432\u043e\u0438\u0445 \u0440\u0430\u0437\u043c\u0435\u0440\u043e\u0432     position: relative;     float: left; \/\/ \u0440\u0430\u0441\u043f\u043e\u043b\u0430\u0433\u0430\u0435\u043c \u0447\u0430\u0441\u0442\u0438 \u0441 \u043f\u043e\u043c\u043e\u0449\u044c\u044e \u043e\u0431\u044b\u0447\u043d\u044b\u0445 \u0444\u043b\u043e\u0430\u0442\u043e\u0432     height: 100%;     cursor: grab;     user-select: none; \/\/ \u0441\u0443\u0449\u0435\u0441\u0442\u0432\u0435\u043d\u043d\u043e \u0443\u043b\u0443\u0447\u0448\u0430\u0435\u0442 \u043a\u0430\u0447\u0435\u0441\u0442\u0432\u043e \u0441\u0432\u0430\u0439\u043f\u0430 \u043c\u044b\u0448\u043a\u043e\u0439      &-inner {       position: absolute;       top: 0;       \/\/ left \u0431\u0443\u0434\u0435\u043c \u0443\u043a\u0430\u0437\u044b\u0432\u0430\u0442\u044c \u0443\u0436\u0435 \u0441 \u043f\u043e\u043c\u043e\u0449\u044c\u044e js       width: 100vw; \/\/ \u043a\u0430\u0436\u0434\u044b\u0439 \u0432\u043d\u0443\u0442\u0440\u0435\u043d\u043d\u0438\u0439 \u0431\u043b\u043e\u043a \u0437\u0430\u043d\u0438\u043c\u0430\u0435\u0442 100% \u0448\u0438\u0440\u0438\u043d\u044b \u044d\u043a\u0440\u0430\u043d\u0430       height: 100%;       background-size: cover;       background-position: center center;     }    } } <\/code><\/pre>\n<p>  <\/p>\n<pre><code class=\"javascript\">var $wsPages = $(&quot;.ws-pages&quot;); var bgParts = 24; \/\/ \u043f\u0443\u0441\u0442\u044c \u0443 \u043d\u0430\u0441 \u0431\u0443\u0434\u0435\u0442 24 \u0447\u0430\u0441\u0442\u0438. var $parts;  function initBgs() {   var arr = [];   var partW = 100 \/ bgParts; \/\/ \u0434\u043b\u0438\u043d\u0430 \u043e\u0434\u043d\u043e\u0439 \u0447\u0430\u0441\u0442\u0438, \u0432 %        for (var i = 1; i &lt;= bgParts; i++) {     var $part = $('&lt;div class=&quot;ws-bg__part&quot;&gt;'); \/\/ \u0441\u043e\u0437\u0434\u0430\u0435\u043c \u0447\u0430\u0441\u0442\u044c \u0431\u044d\u043a\u0433\u0440\u0430\u0443\u043d\u0434\u0430     var $inner = $('&lt;div class=&quot;ws-bg__part-inner&quot;&gt;'); \/\/ \u0430 \u0442\u0430\u043a \u0436\u0435 \u0432\u043d\u0443\u0442\u0440\u0435\u043d\u043d\u0438\u0439 \u0435\u0451 \u0431\u043b\u043e\u043a     var innerLeft = 100 \/ bgParts * (1 - i); \/\/ \u0440\u0430\u0441\u0447\u0438\u0442\u044b\u0432\u0430\u0435\u043c \u043f\u043e\u0437\u0438\u0446\u0438\u044e \u0432\u043d\u0443\u0442\u0440\u0435\u043d\u043d\u0433\u043e \u0431\u043b\u043e\u043a\u0430            $inner.css(&quot;left&quot;, innerLeft + &quot;vw&quot;);     $part.append($inner);     $part.addClass(&quot;ws-bg__part-&quot; + i).width(partW + &quot;%&quot;); \/\/ \u0434\u043e\u0431\u0430\u0432\u043b\u044f\u0435\u043c \u043a\u043b\u0430\u0441\u0441 \u0441 \u0438\u043d\u0434\u0435\u043a\u0441\u043e\u043c \u0434\u043b\u044f \u043a\u0430\u0436\u0434\u043e\u0439 \u0447\u0430\u0441\u0442\u0438 \u0438 \u043d\u0430\u0437\u043d\u0430\u0447\u0430\u0435\u043c \u0448\u0438\u0440\u0438\u043d\u0443     arr.push($part);   }        $(&quot;.ws-bg&quot;).append(arr); \/\/ \u0432 \u043a\u0430\u0436\u0434\u044b\u0439 \u0431\u043b\u043e\u043a \u0432\u0441\u0442\u0430\u0432\u043b\u044f\u0435\u043c \u043c\u0430\u0441\u0441\u0438\u0432 \u0441 \u0447\u0430\u0441\u0442\u044f\u043c\u0438   $wsPages.addClass(&quot;s--ready&quot;); \/\/ \u043e\u0431 \u044d\u0442\u043e\u043c \u0431\u0443\u0434\u0435\u0442 \u043d\u0430\u043f\u0438\u0441\u0430\u043d\u043e \u043d\u0438\u0436\u0435   $parts = $(&quot;.ws-bg__part&quot;); };  initBgs(); <\/code><\/pre>\n<p>  <\/p>\n<div class=\"spoiler\"><b class=\"spoiler_title\">\u041a\u0430\u043a \u044d\u0442\u043e \u0431\u044b\u043b\u043e \u0440\u0435\u0430\u043b\u0438\u0437\u043e\u0432\u0430\u043d\u043e \u0438\u0437\u043d\u0430\u0447\u0430\u043b\u044c\u043d\u043e<\/b><\/p>\n<div class=\"spoiler_text\">\u0418\u0437\u043d\u0430\u0447\u0430\u043b\u044c\u043d\u043e \u044f \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043b :after \u0434\u043b\u044f .ws-bg__part \u0438 \u0446\u0438\u043a\u043b\u043e\u043c \u0432 sass \u0432\u044b\u0441\u0442\u0430\u0432\u043b\u044f\u043b left \u0434\u043b\u044f \u043f\u0441\u0435\u0432\u0434\u043e\u044d\u043b\u0435\u043c\u0435\u043d\u0442\u043e\u0432. \u041d\u043e \u043f\u043e\u0442\u043e\u043c \u0440\u0435\u0448\u0438\u043b \u0447\u0442\u043e \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e\u0441\u0442\u044c \u0441\u0438\u043d\u0445\u0440\u043e\u043d\u0438\u0437\u0430\u0446\u0438\u0438 \u043f\u0435\u0440\u0435\u043c\u0435\u043d\u043d\u044b\u0445 \u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u0430 \u0447\u0430\u0441\u0442\u0435\u0439 \u0432 js \u0438 sass \u044d\u0442\u043e \u043f\u043b\u043e\u0445\u0430\u044f \u043f\u0440\u0430\u043a\u0442\u0438\u043a\u0430 \u0438 \u0441\u0434\u0435\u043b\u0430\u043b \u0432\u0441\u0435 \u043f\u043e\u043b\u043d\u043e\u0441\u0442\u044c\u044e \u043d\u0430 js.  <\/div>\n<\/div>\n<p>  \u0418\u0442\u0430\u043a, \u043f\u043e\u0434 \u043a\u043e\u043d\u0435\u0446 \u0444\u0443\u043d\u043a\u0446\u0438\u0438 \u043c\u044b \u0434\u043e\u0431\u0430\u0432\u043b\u044f\u0435\u043c \u043a \u043a\u043e\u043d\u0442\u0435\u0439\u043d\u0435\u0440\u0443 \u043a\u043b\u0430\u0441\u0441 s&#8212;ready. \u041d\u0430\u043c \u044d\u0442\u043e \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e \u0434\u043b\u044f \u0442\u043e\u0433\u043e, \u0447\u0442\u043e\u0431\u044b \u0443\u0431\u0440\u0430\u0442\u044c \u0444\u043e\u043d \u0441 \u0431\u043b\u043e\u043a\u043e\u0432 .ws-bg, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u0438\u0437\u043d\u0430\u0447\u0430\u043b\u044c\u043d\u043e \u0431\u0443\u0434\u0443\u0442 \u043e\u0442\u043e\u0431\u0440\u0430\u0436\u0430\u0442\u044c\u0441\u044f \u0441 \u0444\u043e\u043d\u043e\u043c, \u0447\u0442\u043e\u0431\u044b \u044e\u0437\u0435\u0440 \u0432\u0438\u0434\u0435\u043b \u043a\u043e\u043d\u0442\u0435\u043d\u0442, \u0434\u043e \u0442\u043e\u0433\u043e \u043a\u0430\u043a javascript \u0434\u043e\u0431\u0430\u0432\u0438\u0442 \u0447\u0430\u0441\u0442\u0438. \u041f\u043e\u0441\u043b\u0435 \u0442\u043e\u0433\u043e \u043a\u0430\u043a \u0447\u0430\u0441\u0442\u0438 \u0434\u043e\u0431\u0430\u0432\u043b\u0435\u043d\u044b, \u0444\u043e\u043d \u0443 \u043e\u0441\u043d\u043e\u0432\u043d\u044b\u0445 \u0431\u043b\u043e\u043a\u043e\u0432 \u043d\u0435 \u043d\u0443\u0436\u0435\u043d, \u0438\u0431\u043e \u043e\u043d\u0438 \u0434\u0432\u0438\u0433\u0430\u0442\u044c\u0441\u044f \u043d\u0435 \u0431\u0443\u0434\u0443\u0442. \u0422\u0430\u043a \u0447\u0442\u043e \u0434\u043e\u0431\u0430\u0432\u043b\u044f\u0435\u043c \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u0435 \u0434\u043b\u044f .ws-bg.<\/p>\n<pre><code class=\"css\">.ws-bg {    .ws-pages.s--ready & { \/\/ \u043a\u043e\u043c\u043f\u0438\u043b\u0438\u0440\u0443\u0435\u0442\u0441\u044f \u0432 .ws-pages.s--ready .ws-bg     background: none;   } }  \/\/ \u043d\u0443 \u0438 \u043d\u0435 \u0437\u0430\u0431\u044b\u0432\u0430\u0435\u043c \u0434\u043e\u0431\u0430\u0432\u0438\u0442\u044c \u0441\u0430\u043c\u0438 \u0444\u043e\u043d\u043e\u0432\u044b\u0435 \u043a\u0430\u0440\u0442\u0438\u043d\u043a\u0438 \u0434\u043b\u044f .ws-bg \u0438 \u0432\u043b\u043e\u0436\u0435\u043d\u043d\u044b\u0445 \u0432 \u043d\u0435\u0433\u043e .ws-bg__part-inner c \u043f\u043e\u043c\u043e\u0449\u044c\u044e css \/\/ \u043d\u0430\u0434 \u0432\u0430\u0440\u0438\u0430\u043d\u0442\u043e\u043c, \u0433\u0434\u0435 \u043a\u0430\u0440\u0442\u0438\u043d\u043a\u0438 \u043d\u0435\u043b\u044c\u0437\u044f \u0432\u0441\u0442\u0430\u0432\u0438\u0442\u044c \u0441 \u043f\u043e\u043c\u043e\u0449\u044c\u044e css \u044f \u043d\u0435 \u0434\u0443\u043c\u0430\u043b, \u043d\u043e \u043c\u043d\u0435 \u043a\u0430\u0436\u0435\u0442\u0441\u044f \u0440\u0435\u0448\u0435\u043d\u0438\u0435 \u043c\u043e\u0436\u043d\u043e \u043b\u0435\u0433\u043a\u043e \u043d\u0430\u0439\u0442\u0438 <\/code><\/pre>\n<p>  <\/p>\n<h4>Move your mouse<\/h4>\n<p>  \u041f\u0440\u0438\u0448\u043b\u043e \u0432\u0440\u0435\u043c\u044f \u043d\u0430\u0432\u0435\u0441\u0438\u0442\u044c \u043e\u0431\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a\u0438 \u0434\u043b\u044f \u0441\u0432\u0430\u0439\u043f\u0430 \u043c\u044b\u0448\u043a\u043e\u0439 \u0438 \u0440\u0435\u0430\u043b\u0438\u0437\u043e\u0432\u0430\u0442\u044c \u043f\u0435\u0440\u0435\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u0435 \u0441\u0442\u0440\u0430\u043d\u0438\u0446.<\/p>\n<pre><code class=\"javascript\">var curPage = 1; \/\/ \u043f\u0435\u0440\u0435\u043c\u0435\u043d\u043d\u0430\u044f \u0434\u043b\u044f \u0442\u0435\u043a\u0443\u0449\u0435\u0439 \u0441\u0442\u0440\u0430\u043d\u0438\u0446\u044b var numOfPages = $(&quot;.ws-bg&quot;).length; \/\/ \u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u043e \u0441\u0442\u0440\u0430\u043d\u0438\u0446  \/\/ \u0432 \u0446\u0435\u043b\u044f\u0445 \u043f\u0440\u043e\u0441\u0442\u0435\u0439\u0448\u0435\u0439 \u043e\u043f\u0442\u0438\u043c\u0438\u0437\u0430\u0446\u0438\u0438 \u0441\u043e\u0445\u0440\u0430\u043d\u044f\u0435\u043c \u0440\u0430\u0437\u043c\u0435\u0440\u044b \u043e\u043a\u043d\u0430 \u0432 \u043f\u0435\u0440\u0435\u043c\u0435\u043d\u043d\u044b\u0435 var winW = $(window).width(); var winH = $(window).height();  \/\/ \u0432\u0435\u0448\u0430\u0435\u043c \u043e\u0431\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a \u043d\u0430 \u0440\u0435\u0441\u0430\u0439\u0437 \u043e\u043a\u043d\u0430, \u0434\u0430\u0431\u044b \u043e\u0431\u043d\u043e\u0432\u043b\u044f\u0442\u044c \u043f\u0435\u0440\u0435\u043c\u0435\u043d\u043d\u044b\u0435 \u0435\u0433\u043e \u0440\u0430\u0437\u043c\u0435\u0440\u043e\u0432 $(window).on(&quot;resize&quot;, function() {   winW = $(window).width();   winH = $(window).height(); });  var startY = 0; var deltaY = 0;  $(document).on(&quot;mousedown&quot;, &quot;.ws-bg__part&quot;, function(e) { \/\/ \u0432\u0435\u0448\u0430\u0435\u043c \u043e\u0431\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a \u0441 \u043f\u043e\u043c\u043e\u0449\u044c\u044e \u0434\u0435\u043b\u0435\u0433\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u044f \u0441\u043e\u0431\u044b\u0442\u0438\u0439   startY = e.pageY; \/\/ \u0441\u0442\u0430\u0440\u0442\u043e\u0432\u0430\u044f Y \u043f\u043e\u0437\u0438\u0446\u0438\u044f \u043c\u044b\u0448\u0438 \u0432 \u043d\u0430\u0447\u0430\u043b\u0435 \u0441\u0432\u0430\u0439\u043f\u0430   deltaY = 0; \/\/ \u043e\u0431\u043d\u0443\u043b\u044f\u0435\u043c \u043f\u0435\u0440\u0435\u043c\u0435\u043d\u043d\u0443\u044e \u043f\u0440\u0438 \u043a\u0430\u0436\u0434\u043e\u043c \u043d\u043e\u0432\u043e\u043c \u0441\u0432\u0430\u0439\u043f\u0435    $(document).on(&quot;mousemove&quot;, mousemoveHandler); \/\/ \u0432\u0435\u0448\u0430\u0435\u043c \u043e\u0431\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a \u0434\u043b\u044f \u0434\u0432\u0438\u0436\u0435\u043d\u0438\u044f \u043c\u044b\u0448\u044c\u044e    $(document).on(&quot;mouseup&quot;, swipeEndHandler); \/\/ \u0438 \u0434\u043b\u044f \u043e\u043a\u043e\u043d\u0447\u0430\u043d\u0438\u044f \u0441\u0432\u0430\u0439\u043f\u0430 });  var mousemoveHandler = function(e) {   var y = e.pageY;    \/\/ \u0441 \u043f\u043e\u043c\u043e\u0449\u044c\u044e X \u043a\u043e\u043e\u0440\u0434\u0438\u043d\u0430\u0442\u044b \u043f\u043e\u043b\u0443\u0447\u0430\u0435\u043c \u0438\u043d\u0434\u0435\u043a\u0441 \u0442\u043e\u0439 \u0447\u0430\u0441\u0442\u0438, \u043d\u0430 \u043a\u043e\u0442\u043e\u0440\u043e\u0439 \u0432 \u0434\u0430\u043d\u043d\u044b\u0439 \u043c\u043e\u043c\u0435\u043d\u0442 \u043d\u0430\u0445\u043e\u0434\u0438\u0442\u0441\u044f \u0443\u043a\u0430\u0437\u0430\u0442\u0435\u043b\u044c \u043c\u044b\u0448\u0438   var x = e.pageX;   index = Math.ceil(x \/ winW * bgParts);    deltaY = y - startY; \/\/ \u0432\u044b\u0447\u0438\u0441\u043b\u044f\u0435\u043c \u0440\u0430\u0437\u043d\u0438\u0446\u0443 \u043c\u0435\u0436\u0434\u0443 \u0442\u0435\u043a\u0443\u0449\u0435\u0439 \u0438 \u0441\u0442\u0430\u0440\u0442\u043e\u0432\u043e\u0439 \u043f\u043e\u0437\u0438\u0446\u0438\u044f\u043c\u0438   moveParts(deltaY, index); \/\/ \u0434\u0432\u0438\u0433\u0430\u0442\u044c \u0447\u0430\u0441\u0442\u0438 \u0431\u0443\u0434\u0435\u043c \u0432 \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u043e\u0439 \u0444\u0443\u043d\u043a\u0446\u0438\u0438 };  var swipeEndHandler = function() {   \/\/ \u0441\u043d\u0438\u043c\u0430\u0435\u043c \u043e\u0431\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a\u0438 \u0434\u0432\u0438\u0436\u0435\u043d\u0438\u044f\/\u043e\u043a\u043e\u043d\u0447\u0430\u043d\u0438\u044f \u0441\u0432\u0430\u0439\u043f\u0430   $(document).off(&quot;mousemove&quot;, mousemoveHandler);   $(document).off(&quot;mouseup&quot;, swipeEndHandler);    if (!deltaY) return; \/\/ \u0435\u0441\u043b\u0438 \u0434\u0432\u0438\u0436\u0435\u043d\u0438\u044f \u043f\u043e \u043e\u0441\u0438 Y \u043d\u0435 \u0431\u044b\u043b\u043e, \u0442\u043e \u0437\u0434\u0435\u0441\u044c \u0438 \u0437\u0430\u043a\u0430\u043d\u0447\u0438\u0432\u0430\u0435\u043c    \/\/ \u0435\u0441\u043b\u0438 &quot;\u0440\u0430\u0441\u0441\u0442\u043e\u044f\u043d\u0438\u0435 \u0441\u0432\u0430\u0439\u043f\u0430&quot; \u0431\u043e\u043b\u044c\u0448\u0435 \u043f\u043e\u043b\u043e\u0432\u0438\u043d\u044b \u044d\u043a\u0440\u0430\u043d\u0430 \u0432 \u043e\u043f\u0440\u0435\u0434\u0435\u043b\u0435\u043d\u043d\u043e\u043c \u043d\u0430\u043f\u0440\u0430\u0432\u043b\u0435\u043d\u0438\u0438, \u0432\u044b\u0437\u044b\u0432\u0430\u0435\u043c \u0444\u0443\u043d\u043a\u0446\u0438\u044e \u0434\u043b\u044f \u0441\u043c\u0435\u043d\u044b \u0441\u0442\u0440\u0430\u043d\u0438\u0446\u044b   if (deltaY \/ winH &gt;= 0.5) navigateUp();   if (deltaY \/ winH &lt;= -0.5) navigateDown();    \/\/ \u0434\u0432\u0438\u0433\u0430\u0435\u043c \u0432\u0441\u0435 \u0447\u0430\u0441\u0442\u0438   \/\/ \u0434\u0430\u0436\u0435 \u0435\u0441\u043b\u0438 \u0441\u0442\u0440\u0430\u043d\u0438\u0446\u0430 \u043e\u0441\u0442\u0430\u043b\u0430\u0441\u044c \u0442\u043e\u0439 \u0436\u0435, \u043d\u0430\u043c \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e \u0432\u0435\u0440\u043d\u0443\u0442\u044c \u0432\u0441\u0435 \u0447\u0430\u0441\u0442\u0438 \u043d\u0430 \u0438\u0441\u0445\u043e\u0434\u043d\u0443\u044e \u043f\u043e\u0437\u0438\u0446\u0438\u044e \u0434\u043b\u044f \u0442\u0435\u043a\u0443\u0449\u0435\u0439 \u0441\u0442\u0440\u0430\u043d\u0438\u0446\u044b   changePages();  };  \/\/ \u043a\u0440\u0430\u0439\u043d\u0435 \u043f\u0440\u043e\u0441\u0442\u044b\u0435 \u0444\u0443\u043d\u043a\u0446\u0438\u0438 \u0434\u043b\u044f \u0438\u0437\u043c\u0435\u043d\u0435\u043d\u0438\u044f \u043f\u0435\u0440\u0435\u043c\u0435\u043d\u043d\u043e\u0439 \u0442\u0435\u043a\u0443\u0449\u0435\u0439 \u0441\u0442\u0440\u0430\u043d\u0438\u0446\u044b function navigateUp() {   if (curPage &gt; 1) curPage--; };  function navigateDown() {   if (curPage &lt; numOfPages) curPage++; }; <\/code><\/pre>\n<p>  \u0414\u043e\u0431\u0430\u0432\u043b\u044f\u0435\u043c \u0444\u0443\u043d\u043a\u0446\u0438\u043e\u043d\u0430\u043b \u0434\u0432\u0438\u0436\u0435\u043d\u0438\u044f \u0447\u0430\u0441\u0442\u0435\u0439, \u043d\u0430 \u043e\u0441\u043d\u043e\u0432\u0435 \u043f\u0435\u0440\u0435\u043c\u0435\u043d\u043d\u044b\u0445 deltaY \u0438 index (\u0432\u044b\u0437\u043e\u0432 \u0444\u0443\u043d\u043a\u0446\u0438\u0438 moveParts \u0432\u043d\u0443\u0442\u0440\u0438 mousemoveHandler). \u041d\u0430\u043c \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e \u0441\u0434\u0435\u043b\u0430\u0442\u044c \u044d\u0444\u0444\u0435\u043a\u0442 \u0434\u0432\u0443\u0441\u0442\u043e\u0440\u043e\u043d\u043d\u0435\u0439 \u043b\u0435\u0441\u0435\u043d\u043a\u0438, \u043a\u043e\u0433\u0434\u0430 \u043a\u0430\u0436\u0434\u0430\u044f \u0447\u0430\u0441\u0442\u044c, \u043d\u0430\u0445\u043e\u0434\u044f\u0449\u0430\u044f\u0441\u044f \u0441 \u043b\u044e\u0431\u043e\u0439 \u0438\u0437 \u0441\u0442\u043e\u0440\u043e\u043d \u043e\u0442 \u0430\u043a\u0442\u0438\u0432\u043d\u043e\u0439 \u0447\u0430\u0441\u0442\u0438 (\u0442\u043e\u0439, \u043d\u0430 \u043a\u043e\u0442\u043e\u0440\u043e\u0439 \u043d\u0430\u0445\u043e\u0434\u0438\u0442\u0441\u044f \u0443\u043a\u0430\u0437\u0430\u0442\u0435\u043b\u044c) \u043d\u0430\u0447\u0438\u043d\u0430\u0435\u0442 \u0434\u0432\u0438\u0433\u0430\u0442\u044c\u0441\u044f \u043f\u043e \u043e\u0441\u0438 Y \u0441 \u043e\u043f\u0440\u0435\u0434\u0435\u043b\u0435\u043d\u043d\u043e\u0439 \u0437\u0430\u0434\u0435\u0440\u0436\u043a\u043e\u0439 \u043f\u043e \u0440\u0430\u0441\u0441\u0442\u043e\u044f\u043d\u0438\u044e \u0441\u0432\u0430\u0439\u043f\u0430 (\u043e\u043f\u0438\u0441\u0430\u0442\u044c \u043d\u0430 \u0441\u043b\u043e\u0432\u0430\u0445 \u044d\u0442\u043e \u043d\u0430\u043c\u043d\u043e\u0433\u043e \u0441\u043b\u043e\u0436\u043d\u0435\u0435 \u0447\u0435\u043c \u043f\u043e\u043d\u044f\u0442\u044c \u0432\u0438\u0437\u0443\u0430\u043b\u044c\u043d\u043e). \u041f\u0440\u0438 \u044d\u0442\u043e\u043c \u0447\u0435\u043c \u0434\u0430\u043b\u044c\u0448\u0435 \u0447\u0430\u0441\u0442\u044c \u043d\u0430\u0445\u043e\u0434\u0438\u0442\u0441\u044f \u043e\u0442 \u0430\u043a\u0442\u0438\u0432\u043d\u043e\u0439, \u0442\u0435\u043c \u043c\u0435\u043d\u044c\u0448\u0435 \u0434\u043e\u043b\u0436\u043d\u0430 \u0431\u044b\u0442\u044c \u0435\u0451 \u00ab\u0432\u044b\u0441\u043e\u0442\u0430 \u0441\u0442\u0443\u043f\u0435\u043d\u044c\u043a\u0438\u00bb.<\/p>\n<div class=\"spoiler\"><b class=\"spoiler_title\">\u0422\u043e\u043b\u044c\u043a\u043e \u043d\u0435 \u0431\u0435\u0439\u0442\u0435<\/b><\/p>\n<div class=\"spoiler_text\">\u0424\u0443\u043d\u043a\u0446\u0438\u043e\u043d\u0430\u043b \u0434\u0432\u0438\u0436\u0435\u043d\u0438\u044f \u0447\u0430\u0441\u0442\u0435\u0439 \u044f \u043f\u0438\u0441\u0430\u043b \u043f\u043e\u0437\u0434\u043d\u0435\u0439 \u043d\u043e\u0447\u044c\u044e, \u043a\u043e\u0433\u0434\u0430 \u0443\u0436\u0435 \u0434\u043e\u043b\u0436\u0435\u043d \u0431\u044b\u043b \u0441\u043b\u0430\u0434\u043a\u043e \u0441\u043f\u0430\u0442\u044c. \u0410 \u043f\u043e\u0442\u043e\u043c \u043c\u043d\u0435 \u0431\u044b\u043b\u043e \u043b\u0435\u043d\u044c \u0432\u0441\u0435 \u044d\u0442\u043e \u0434\u0435\u043b\u043e \u0440\u0435\u0444\u0430\u043a\u0442\u043e\u0440\u0438\u0442\u044c \u043f\u043e \u0443\u043c\u0443, \u0442\u0430\u043a \u0447\u0442\u043e \u0432\u0430\u043c \u043e\u0441\u0442\u0430\u0435\u0442\u0441\u044f \u043b\u0438\u0448\u044c \u043b\u0438\u0446\u0435\u0437\u0440\u0435\u0442\u044c \u044d\u0442\u043e\u0442 \u0443\u0436\u0430\u0441. \u0415\u0441\u043b\u0438 \u043a\u0442\u043e-\u0442\u043e \u0432 \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u0438 \u044d\u0442\u043e \u043a\u0440\u0430\u0441\u0438\u0432\u043e \u0437\u0430\u0440\u0435\u0444\u0430\u043a\u0442\u043e\u0440\u0438\u0442\u044c, \u0431\u0443\u0434\u0443 \u0440\u0430\u0434 \u043f\u043e\u043c\u043e\u0449\u0438 \u0432 \u043a\u043e\u043c\u043c\u0435\u043d\u0442\u0430\u0445.<\/p>\n<p>  \u0422\u0430\u043a \u0436\u0435 \u044f \u0438\u0441\u043f\u044b\u0442\u0430\u043b \u0441\u0443\u0449\u0435\u0441\u0442\u0432\u0435\u043d\u043d\u044b\u0435 \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u044b \u0441 \u0430\u0434\u0435\u043a\u0432\u0430\u0442\u043d\u044b\u043c \u043e\u043f\u0438\u0441\u0430\u043d\u0438\u0435\u043c \u043f\u0440\u043e\u0438\u0441\u0445\u043e\u0434\u044f\u0449\u0435\u0433\u043e, \u043d\u0430 \u0441\u0430\u043c\u043e\u043c \u0434\u0435\u043b\u0435 \u0442\u0430\u043c \u0432\u0441\u0435 \u043f\u0440\u043e\u0449\u0435 \u0438 \u043f\u043e\u043d\u044f\u0442\u043d\u0435\u0435 \u0447\u0435\u043c \u043a\u0430\u0436\u0435\u0442\u0441\u044f, \u043f\u0440\u043e\u0441\u0442\u043e \u044f \u0441\u0435\u0439\u0447\u0430\u0441 \u043f\u043e \u0445\u043e\u0434\u0443 \u043d\u0435 \u0432 \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u0438 \u043d\u043e\u0440\u043c\u0430\u043b\u044c\u043d\u043e \u0432\u044b\u0440\u0430\u0436\u0430\u0442\u044c \u0441\u0432\u043e\u0438 \u043c\u044b\u0441\u043b\u0438 =\/  <\/div>\n<\/div>\n<p>  <\/p>\n<pre><code class=\"javascript\">var staggerVal = 65; \/\/ \u0441\u0442\u0430\u0440\u0442\u043e\u0432\u043e\u0435 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435 \u043e\u0442\u043a\u043b\u043e\u043d\u0435\u043d\u0438\u044f \u0441\u043e\u0441\u0435\u0434\u043d\u0438\u0445 \u0447\u0430\u0441\u0442\u0435\u0439 var staggerStep = 4; \/\/ \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435, \u043a\u043e\u0442\u043e\u0440\u043e\u0435 \u0441 \u043a\u0430\u0436\u0434\u044b\u043c \u043f\u043e\u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0438\u043c \u0448\u0430\u0433\u043e\u043c \u0431\u0443\u0434\u0435\u0442 \u043f\u043e\u043d\u0438\u0436\u0430\u0442\u044c \u0432\u044b\u0441\u043e\u0442\u0443 \u0441\u0442\u0443\u043f\u0435\u043d\u044c\u043a\u0438  var changeAT = 0.5; \/\/ \u0432\u0440\u0435\u043c\u044f \u0430\u043d\u0438\u043c\u0430\u0446\u0438\u0438 \u0432 \u0441\u0435\u043a\u0443\u043d\u0434\u0430\u0445  function moveParts(y, index) { \/\/ y = deltaY; index - \u0438\u043d\u0434\u0435\u043a\u0441 \u0430\u043a\u0442\u0438\u0432\u043d\u043e\u0433\u043e \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u0430   var leftMax = index - 1; \/\/ \u043c\u0430\u043a\u0441\u0438\u043c\u0430\u043b\u044c\u043d\u044b\u0439 \u0438\u043d\u0434\u0435\u043a\u0441 \u0447\u0430\u0441\u0442\u0438 \u0441\u043b\u0435\u0432\u0430 \u043e\u0442 \u0430\u043a\u0442\u0438\u0432\u043d\u043e\u0439   var rightMin = index + 1; \/\/ \u0438 \u043c\u0438\u043d\u0438\u043c\u0430\u043b\u044c\u043d\u044b\u0439 \u0438\u043d\u0434\u0435\u043a\u0441 \u0447\u0430\u0441\u0442\u0438 \u0441\u043f\u0440\u0430\u0432\u0430    \/\/ \u043f\u0435\u0440\u0435\u043c\u0435\u043d\u043d\u044b\u0435 \u0434\u043b\u044f \u0430\u043a\u043a\u0443\u043c\u0443\u043b\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u044b\u0445 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0439 \u043e\u0442\u0441\u0442\u0443\u043f\u0430 \u0447\u0430\u0441\u0442\u0435\u0439 \u043e\u0442 \u0430\u043a\u0442\u0438\u0432\u043d\u043e\u0439   var stagLeft = 0;   var stagRight = 0;    \/\/ \u043f\u0435\u0440\u0435\u043c\u0435\u043d\u043d\u044b\u0435 \u0434\u043b\u044f \u0441\u0443\u043c\u043c\u0430\u0440\u043d\u043e\u0433\u043e \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u044f \u0448\u0430\u0433\u043e\u0432 \u0443\u043c\u0435\u043d\u044c\u0448\u0435\u043d\u0438\u044f \u043e\u0442\u043a\u043b\u043e\u043d\u0435\u043d\u0438\u044f   var stagStepL = 0;   var stagStepR = 0;   var sign = (y &gt; 0) ? -1 : 1; \/\/ \u043e\u043f\u0440\u0435\u0434\u0435\u043b\u044f\u0435\u043c \u043d\u0430\u043f\u0440\u0430\u0432\u043b\u0435\u043d\u0438\u0435 \u0434\u0432\u0438\u0436\u0435\u043d\u0438\u044f    movePart(&quot;.ws-bg__part-&quot; + index, y); \/\/ \u0434\u0432\u0438\u0433\u0430\u0435\u043c \u0430\u043a\u0442\u0438\u0432\u043d\u0443\u044e \u0447\u0430\u0441\u0442\u044c    for (var i = leftMax; i &gt; 0; i--) { \/\/ \u0441\u0442\u0430\u0440\u0442\u0443\u0435\u043c \u0446\u0438\u043a\u043b &quot;\u0441\u043f\u0440\u0430\u0432\u0430 \u043d\u0430\u043b\u0435\u0432\u043e&quot; \u043f\u043e \u0447\u0430\u0441\u0442\u044f\u043c \u0441\u043b\u0435\u0432\u0430 \u043e\u0442 \u0430\u043a\u0442\u0438\u0432\u043d\u043e\u0439     var step = index - i; \/\/ \u0442\u043e, \u043d\u0430\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u0447\u0430\u0441\u0442\u044c \u0434\u0430\u043b\u0435\u043a\u0430 \u043e\u0442 \u0430\u043a\u0442\u0438\u0432\u043d\u043e\u0439      \/\/ \u0432\u044b\u0447\u0438\u0442\u0430\u0435\u043c \u0438\u0437 \u0441\u0442\u0430\u0440\u0442\u043e\u0432\u043e\u0433\u043e \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u044f \u043e\u0442\u043a\u043b\u043e\u043d\u0435\u043d\u0438\u044f \u043f\u0435\u0440\u0435\u043c\u0435\u043d\u043d\u0443\u044e \u0441\u0443\u043c\u043c\u0430\u0440\u043d\u043e\u0433\u043e \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u044f \u0448\u0430\u0433\u043e\u0432 \u0443\u043c\u0435\u043d\u044c\u0448\u0435\u043d\u0438\u044f \u043e\u0442\u043a\u043b\u043e\u043d\u0435\u043d\u0438\u044f     var sVal = staggerVal - stagStepL;      \/\/ \u0434\u043b\u044f \u043f\u0435\u0440\u0432\u044b\u0445 15 \u0441\u0442\u0443\u043f\u0435\u043d\u0435\u043a \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u043e\u0431\u044b\u0447\u043d\u044b\u0439 \u0448\u0430\u0433, \u0437\u0430\u0442\u0435\u043c \u043e\u043d \u043f\u043e\u043d\u0438\u0436\u0430\u0435\u0442\u0441\u044f \u0434\u043e 1     \/\/ \u043c\u0430\u0433\u0438\u0447\u0435\u0441\u043a\u0438\u0435 \u0446\u0438\u0444\u0440\u044b \u044d\u0442\u043e \u043f\u043b\u043e\u0445\u043e. \u041d\u0435 \u0434\u0435\u043b\u0430\u0439\u0442\u0435 \u0442\u0430\u043a.     stagStepL += (step &lt;= 15) ? staggerStep : 1;      \/\/ \u0432 \u0442\u043e\u043c \u043c\u0435\u0441\u0442\u0435 \u0433\u0434\u0435 \u0437\u0430\u043a\u0430\u043d\u0447\u0438\u0432\u0430\u0435\u0442\u0441\u044f \u043b\u0435\u0441\u0435\u043d\u043a\u0430 \u043f\u0443\u0441\u0442\u044c \u043b\u0443\u0447\u0448\u0435 \u0431\u0443\u0434\u0435\u0442 \u0440\u043e\u0432\u043d\u044b\u0439 \u043f\u043e\u043b, \u0430 \u043d\u0435 \u043d\u0430\u0447\u0430\u043b\u043e \u0434\u0440\u0443\u0433\u043e\u0439 \u043b\u0435\u0441\u0442\u043d\u0438\u0446\u044b \u0432 \u043e\u0431\u0440\u0430\u0442\u043d\u043e\u043c \u043d\u0430\u043f\u0440\u0430\u0432\u043b\u0435\u043d\u0438\u0438     if (sVal &lt; 0) sVal = 0;     stagLeft += sVal; \/\/ \u0448\u0430\u0433 \u0442\u0435\u043a\u0443\u0449\u0435\u0439 \u0441\u0442\u0443\u043f\u0435\u043d\u044c\u043a\u0438 \u043f\u0440\u0438\u0431\u0430\u0432\u043b\u044f\u0435\u043c \u043a\u043e \u0432\u0441\u0435\u0439 \u0441\u0443\u043c\u043c\u0430\u0440\u043d\u043e\u0439 \u0432\u044b\u0441\u043e\u0442\u0435 \u043f\u0440\u0435\u0434\u044b\u0434\u0443\u0449\u0438\u0445 \u0441\u0442\u0443\u043f\u0435\u043d\u0435\u043a     var nextY = y + stagLeft * sign; \/\/ Y \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435 \u0434\u043b\u044f \u0441\u0442\u0443\u043f\u0435\u043d\u044c\u043a\u0438      \/\/ \u0435\u0441\u043b\u0438 \u043e\u0442\u043a\u043b\u043e\u043d\u0435\u043d\u0438\u0435 \u0442\u0435\u043a\u0443\u0449\u0435\u0439 \u0447\u0430\u0441\u0442\u0438 \u043e\u0442 \u0430\u043a\u0442\u0438\u0432\u043d\u043e\u0439 \u0431\u043e\u043b\u044c\u0448\u0435 deltaY \u0430\u043a\u0442\u0438\u0432\u043d\u043e\u0439, \u0442\u043e \u0442\u0435\u043a\u0443\u0449\u0443\u044e \u0447\u0430\u0441\u0442\u044c \u0444\u0438\u043a\u0441\u0438\u0440\u0443\u0435\u043c \u043d\u0430 \u043e\u0431\u044b\u0447\u043d\u043e\u043c \u043c\u0435\u0441\u0442\u0435     if (Math.abs(y) &lt; Math.abs(stagLeft)) nextY = 0;     movePart(&quot;.ws-bg__part-&quot; + i, nextY); \/\/ \u0434\u0432\u0438\u0433\u0430\u0435\u043c \u0447\u0430\u0441\u0442\u044c   }    \/\/ \u0442\u0443\u0442 \u043f\u0440\u043e\u0438\u0441\u0445\u043e\u0434\u0438\u0442 \u0432\u0441\u0435 \u0442\u043e\u0436\u0435 \u0441\u0430\u043c\u043e\u0435 \u0447\u0442\u043e \u0438 \u0432 \u043f\u0440\u043e\u0448\u043b\u043e\u043c \u0446\u0438\u043a\u043b\u0435, \u043d\u043e \u0442\u043e\u043b\u044c\u043a\u043e \u0441\u043b\u0435\u0432\u0430 \u043d\u0430\u043f\u0440\u0430\u0432\u043e \u0434\u043b\u044f \u0447\u0430\u0441\u0442\u0435\u0439 \u0441\u043f\u0440\u0430\u0432\u0430 \u043e\u0442 \u0430\u043a\u0442\u0438\u0432\u043d\u043e\u0439   for (var j = rightMin; j &lt;= bgParts; j++) {     var step = j - index;     var sVal = staggerVal - stagStepR;     stagStepR += (step &lt;= 15) ? staggerStep : 1;     if (sVal &lt; 0) sVal = 0;     stagRight += sVal;     var nextY = y + stagRight * sign;     if (Math.abs(y) &lt; Math.abs(stagRight)) nextY = 0;     movePart(&quot;.ws-bg__part-&quot; + j, nextY);   } };  function movePart($part, y) {   var y = y - (curPage - 1) * winH; \/\/ \u043a\u043e\u0440\u0440\u0435\u043a\u0442\u0438\u0440\u0443\u0435\u043c Y \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435 \u043e\u0442\u043d\u043e\u0441\u0438\u0442\u0435\u043b\u044c\u043d\u043e \u0442\u0435\u043a\u0443\u0449\u0435\u0439 \u0441\u0442\u0440\u0430\u043d\u0438\u0446\u044b    \/\/ \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u043c \u0433\u0441\u0430\u043f \u0434\u043b\u044f \u0430\u043d\u0438\u043c\u0430\u0446\u0438\u0438 (\u043e \u043d\u0435\u043c \u0447\u0443\u0442\u044c \u043d\u0438\u0436\u0435)   \/\/ \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u0435 \u043f\u0440\u043e\u0441\u0442\u043e\u0435:   \/\/ TweenMax.to(%\u0441\u0435\u043b\u0435\u043a\u0442\u043e\u0440%, %\u0432\u0440\u0435\u043c\u044f \u0430\u043d\u0438\u043c\u0430\u0446\u0438\u0438 \u0432 \u0441\u0435\u043a\u0443\u043d\u0434\u0430\u0445%, {%\u0441\u0432\u043e\u0439\u0441\u0442\u0432\u0430 \u0434\u043b\u044f \u0430\u043d\u0438\u043c\u0430\u0446\u0438\u0438 \u0438 \u0434\u043e\u043f\u043e\u043b\u043d\u0438\u0442\u0435\u043b\u044c\u043d\u044b\u0435 \u043d\u0430\u0441\u0442\u0440\u043e\u0439\u043a\u0438%}   \/\/ \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u043c Back easing \u0434\u043b\u044f \u043f\u043e\u0434\u043e\u0431\u0438\u044f \u044d\u0444\u0444\u0435\u043a\u0442\u0430 bounce. \u0421\u0430\u043c bounce \u043f\u0440\u0438 \u0431\u044b\u0441\u0442\u0440\u043e\u043c \u0434\u0432\u0438\u0436\u0435\u043d\u0438\u0438 \u0441\u043c\u043e\u0442\u0440\u0438\u0442\u0441\u044f \u0436\u0443\u0442\u043a\u043e   TweenLite.to($part, changeAT, {y: y, ease: Back.easeOut.config(4)}); }; <\/code><\/pre>\n<p>  \u041a\u0430\u043a \u0432\u044b \u0443\u0436\u0435 \u0437\u0430\u043c\u0435\u0442\u0438\u043b\u0438, \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044e \u044f GSAP (greensock) \u0434\u043b\u044f \u0430\u043d\u0438\u043c\u0430\u0446\u0438\u0438. \u042f \u043f\u0440\u0438\u0432\u044b\u043a \u0434\u0435\u043b\u0430\u0442\u044c \u0431\u043e\u043b\u044c\u0448\u0438\u043d\u0441\u0442\u0432\u043e \u0434\u0435\u043c\u043e\u043a \u0431\u0435\u0437 \u0441\u043f\u0435\u0446\u0438\u0430\u043b\u044c\u043d\u044b\u0445 \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a \u0434\u043b\u044f \u0430\u043d\u0438\u043c\u0430\u0446\u0438\u0438, \u043f\u043e\u0442\u043e\u043c\u0443-\u0447\u0442\u043e \u044d\u0442\u043e \u0432\u0435\u0441\u044c\u043c\u0430 \u0432\u0435\u0441\u0435\u043b\u043e \u0438 \u043e\u0442\u043b\u0438\u0447\u043d\u043e \u043f\u0440\u043e\u043a\u0430\u0447\u0438\u0432\u0430\u0435\u0442, \u043d\u043e \u0432 \u044d\u0442\u043e\u0442 \u0440\u0430\u0437 \u044f \u0440\u0435\u0448\u0438\u043b \u043f\u043e\u0436\u0430\u043b\u0435\u0442\u044c \u0441\u0435\u0431\u044f, \u043a\u043e\u0433\u0434\u0430 \u043f\u043e\u043d\u044f\u043b \u0447\u0442\u043e \u0440\u0435\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u044f \u0432\u0435\u043b\u043e\u0441\u0438\u043f\u0435\u0434\u0430 \u043d\u0430 requestAnimationFrame \u0437\u0430\u0439\u043c\u0435\u0442 \u043d\u0435\u043c\u0430\u043b\u043e \u0432\u0440\u0435\u043c\u0435\u043d\u0438, \u0438\u0431\u043e \u043d\u0430 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u0438 css transition&#8217;s \u0442\u0443\u0442 \u043d\u0438\u043a\u0443\u0434\u0430 \u043d\u0435 \u0443\u0435\u0434\u0435\u0448\u044c. \u0421\u0432\u044f\u0437\u0430\u043d\u043e \u044d\u0442\u043e \u0441 \u0442\u0435\u043c, \u0447\u0442\u043e \u043d\u0430\u043c \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u0430 \u0440\u0435\u0430\u043b\u0442\u0430\u0439\u043c \u0430\u043d\u0438\u043c\u0430\u0446\u0438\u044f, \u043a\u043e\u0442\u043e\u0440\u0430\u044f \u0431\u0443\u0434\u0435\u0442 \u0430\u0432\u0442\u043e\u043c\u0430\u0442\u043e\u043c \u043f\u0430\u0443\u0437\u0438\u0442\u044c \u043f\u0440\u043e\u0448\u043b\u0443\u044e \u0430\u043d\u0438\u043c\u0430\u0446\u0438\u044e \u0438 \u0437\u0430\u043f\u0443\u0441\u043a\u0430\u0442\u044c \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0443\u044e \u043f\u0440\u0438 \u0434\u0432\u0438\u0436\u0435\u043d\u0438\u0438, \u0441\u043e\u0445\u0440\u0430\u043d\u044f\u044f \u043f\u0440\u0438 \u044d\u0442\u043e\u043c \u043f\u043b\u0430\u0432\u043d\u043e\u0441\u0442\u044c.<\/p>\n<p>  \u0422\u0435\u043f\u0435\u0440\u044c \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e \u043d\u0430\u043f\u0438\u0441\u0430\u0442\u044c \u0444\u0443\u043d\u043a\u0446\u0438\u044e \u0441\u043c\u0435\u043d\u044b \u0441\u0442\u0440\u0430\u043d\u0438\u0446. \u0422\u0443\u0442 \u0432\u0441\u0435 \u043f\u0440\u043e\u0441\u0442\u043e, \u043c\u044b \u043f\u043e \u0441\u0443\u0442\u0438 \u0434\u0435\u043b\u0430 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u043c \u0441\u0438\u043b\u044c\u043d\u043e \u043e\u0431\u043b\u0435\u0433\u0447\u0435\u043d\u043d\u044b\u0439 \u0432\u0430\u0440\u0438\u0430\u043d\u0442 \u0444\u0443\u043d\u043a\u0446\u0438\u0438 moveParts:<\/p>\n<pre><code class=\"javascript\">var waveStagger = 0.013; \/\/ \u043c\u044b \u043d\u0435 \u0445\u043e\u0442\u0438\u043c \u0447\u0442\u043e\u0431\u044b \u0432\u0441\u0435 \u0447\u0430\u0441\u0442\u0438 \u0434\u0432\u0438\u0433\u0430\u043b\u0438\u0441\u044c \u043e\u0434\u043d\u043e\u0432\u0440\u0435\u043c\u0435\u043d\u043d\u043e \u043f\u0440\u0438 \u0441\u043c\u0435\u043d\u0435 \u0441\u0442\u0440\u0430\u043d\u0438\u0446 \u0438 \u0434\u043e\u0431\u0430\u0432\u043b\u044f\u0435\u043c \u0448\u0430\u0433 \u0437\u0430\u0434\u0435\u0440\u0436\u043a\u0438 \u0432 13 \u043c\u0441 \/\/ \u043d\u043e \u043f\u0440\u0438 \u044d\u0442\u043e\u043c \u043c\u044b \u0431\u0443\u0434\u0435\u043c \u0432\u044b\u0447\u0438\u0442\u0430\u0442\u044c \u043d\u0430\u043a\u043e\u043f\u043b\u0435\u043d\u043d\u044b\u0439 \u0448\u0430\u0433 \u0438\u0437 \u0432\u0440\u0435\u043c\u0435\u043d\u0438 \u0430\u043d\u0438\u043c\u0430\u0446\u0438\u0438, \u0434\u0430\u0431\u044b \u044e\u0437\u0435\u0440 \u043d\u0435 \u0436\u0434\u0430\u043b \u0432\u0440\u0435\u043c\u0435\u043d\u0438 \u0441\u0432\u0435\u0440\u0445 \u0441\u0442\u0430\u043d\u0434\u0430\u0440\u0442\u043d\u043e\u0433\u043e \u0438\u0437-\u0437\u0430 \u0442\u043e\u0433\u043e, \u0447\u0442\u043e \u043e\u043d \u043f\u043e\u0442\u044f\u043d\u0443\u043b \u0431\u044d\u043a\u0433\u0440\u0430\u0443\u043d\u0434 \u043d\u0430 \u043e\u0434\u043d\u043e\u043c \u0438\u0437 \u043a\u0440\u0430\u0435\u0432  function changePages() {   var y = (curPage - 1) * winH * -1; \/\/ \u043f\u043e\u043b\u043e\u0436\u0435\u043d\u0438\u0435 \u0441 \u0443\u0447\u0435\u0442\u043e\u043c \u0442\u0435\u043a\u0443\u0449\u0435\u0439 \u0441\u0442\u0440\u0430\u043d\u0438\u0446\u044b   var leftMax = index - 1;   var rightMin = index + 1;    TweenLite.to(&quot;.ws-bg__part-&quot; + index, changeAT, {y: y});    for (var i = leftMax; i &gt; 0; i--) {     var d = (index - i) * waveStagger; \/\/ \u0447\u0435\u043c \u0434\u0430\u043b\u044c\u0448\u0435 \u043e\u0442 \u0430\u043a\u0442\u0438\u0432\u043d\u043e\u0439 \u0447\u0430\u0441\u0442\u0438, \u0442\u0435\u043c \u0431\u043e\u043b\u044c\u0448\u0435 \u0437\u0430\u0434\u0435\u0440\u0436\u043a\u0430 \u0438 \u043c\u0435\u043d\u044c\u0448\u0435 \u0432\u0440\u0435\u043c\u044f \u0430\u043d\u0438\u043c\u0430\u0446\u0438\u0438     TweenLite.to(&quot;.ws-bg__part-&quot; + i, changeAT - d, {y: y, delay: d});   }    for (var j = rightMin; j &lt;= bgParts; j++) {     var d = (j - index) * waveStagger;     TweenLite.to(&quot;.ws-bg__part-&quot; + j, changeAT - d, {y: y, delay: d});   } };  \/\/ \u0438 \u0437\u0430\u043e\u0434\u043d\u043e \u0434\u043e\u0431\u0430\u0432\u043b\u044f\u0435\u043c \u0432\u044b\u0437\u043e\u0432 \u044d\u0442\u043e\u0439 \u0444\u0443\u043d\u043a\u0446\u0438\u0438 \u0432 \u043e\u0431\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a \u0440\u0435\u0441\u0430\u0439\u0437\u0430. \u0412\u0435\u0434\u044c \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u044f \u0443 \u043d\u0430\u0441 \u0432\u044b\u0441\u0442\u0430\u0432\u043b\u044f\u044e\u0442\u0441\u044f \u0432 \u043f\u0438\u043a\u0441\u0435\u043b\u044f\u0445 \/\/ \u043f\u0440\u0438 \u0443\u0432\u0435\u043b\u0438\u0447\u0435\u043d\u0438\u0438 \u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u0430 \u0434\u0435\u0439\u0441\u0442\u0432\u0438\u0439 \u0432\u043d\u0443\u0442\u0440\u0438 \u043e\u0431\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a\u0430 \u0440\u0435\u0441\u0430\u0439\u0437\u0430 \u0435\u0433\u043e \u0431\u0435\u0437\u0443\u0441\u043b\u043e\u0432\u043d\u043e \u043d\u0430\u0434\u043e \u0431\u0443\u0434\u0435\u0442 \u043e\u0431\u0435\u0440\u043d\u0443\u0442\u044c \u0432 debounce. $(window).on(&quot;resize&quot;, function() {   winW = $(window).width();   winH = $(window).height();   changePages(); }); <\/code><\/pre>\n<p>  <\/p>\n<div class=\"spoiler\"><b class=\"spoiler_title\">\u0410\u043b\u044c\u0442\u0435\u0440\u043d\u0430\u0442\u0438\u0432\u0430<\/b><\/p>\n<div class=\"spoiler_text\">\u0415\u0441\u043b\u0438 \u0432\u0430\u043c \u043d\u0435 \u043d\u0443\u0436\u043d\u0430 \u0430\u043d\u0438\u043c\u0430\u0446\u0438\u044f \u0441 \u0448\u0430\u0433\u043e\u043c \u0437\u0430\u0434\u0435\u0440\u0436\u043a\u0438, \u0442\u043e \u0444\u0443\u043d\u043a\u0446\u0438\u044e \u043c\u043e\u0436\u043d\u043e \u0441\u043e\u043a\u0440\u0430\u0442\u0438\u0442\u044c \u0434\u043e 2\u0445 \u0441\u0442\u0440\u043e\u0447\u0435\u043a \u043a\u043e\u0434\u0430. \u041d\u043e \u0432\u0430\u0440\u0438\u0430\u043d\u0442 \u0441 \u0437\u0430\u0434\u0435\u0440\u0436\u043a\u043e\u0439 \u043c\u043d\u0435 \u043f\u043e\u043d\u0440\u0430\u0432\u0438\u043b\u0441\u044f \u0431\u043e\u043b\u044c\u0448\u0435 \u0432 \u043f\u043b\u0430\u043d\u0435 \u044d\u0441\u0442\u0435\u0442\u0438\u043a\u0438.  <\/div>\n<\/div>\n<p>  \u0422\u0435\u043f\u0435\u0440\u044c \u043c\u044b \u0443\u043c\u0435\u0435\u043c \u0434\u0432\u0438\u0433\u0430\u0442\u044c \u0431\u044d\u043a\u0433\u0440\u0430\u0443\u043d\u0434 \u0441\u0432\u0430\u0439\u043f\u043e\u043c \u043c\u044b\u0448\u043a\u043e\u0439. \u0421 \u043f\u0440\u043e\u043c\u0435\u0436\u0443\u0442\u043e\u0447\u043d\u044b\u043c \u0432\u0430\u0440\u0438\u0430\u043d\u0442\u043e\u043c \u0434\u0435\u043c\u043a\u0438 \u043c\u043e\u0436\u043d\u043e \u043e\u0437\u043d\u0430\u043a\u043e\u043c\u0438\u0442\u044c\u0441\u044f <a href=\"http:\/\/codepen.io\/suez\/pen\/b7ccd9206454ccf62d17eef7a94db020\">\u0432\u043e\u0442 \u0442\u0443\u0442<\/a>.<\/p>\n<h4>WaveSCROLL<\/h4>\n<p>  \u0414\u0430\u043b\u0435\u0435, \u043d\u0430\u0432\u0435\u0448\u0438\u0432\u0430\u0435\u043c \u043e\u0431\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a\u0438 \u043d\u0430 \u043a\u043e\u043b\u0435\u0441\u043e \u043c\u044b\u0448\u0438 \u0438 \u0441\u0442\u0440\u0435\u043b\u043a\u0438, \u0434\u0430\u0431\u044b \u043f\u0440\u0435\u0432\u0440\u0430\u0442\u0438\u0442\u044c \u0434\u0435\u043c\u043a\u0443 \u0432 \u043f\u043e\u043b\u043d\u043e\u0446\u0435\u043d\u043d\u0443\u044e \u0440\u0435\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u044e one page scroll. \u041d\u0443 \u0438 \u0437\u0430\u043e\u0434\u043d\u043e \u0441\u0442\u0430\u043d\u0435\u0442 \u043f\u043e\u043d\u044f\u0442\u043d\u043e, \u043f\u043e\u0447\u0435\u043c\u0443 \u0432\u044b\u0431\u0440\u0430\u043d\u043e \u0438\u043c\u0435\u043d\u043d\u043e \u0442\u0430\u043a\u043e\u0435 \u043d\u0430\u0437\u0432\u0430\u043d\u0438\u0435 (\u0445\u043e\u0442\u044f \u043f\u0440\u0438\u0434\u0443\u043c\u0430\u043b \u0435\u0433\u043e \u043d\u0435 \u044f, \u043c\u043d\u0435 \u043f\u043e\u043c\u043e\u0433\u043b\u0438).<\/p>\n<pre><code class=\"javascript\">\/\/ \u0441\u043e\u0437\u0434\u0430\u0435\u043c \u043f\u0435\u0440\u0435\u043c\u0435\u043d\u043d\u0443\u044e, \u0438\u0431\u043e \u043c\u044b \u043d\u0435 \u0445\u043e\u0442\u0438\u043c \u0447\u0442\u043e\u0431\u044b \u044e\u0437\u0435\u0440 \u0437\u0430 \u0434\u043e\u043b\u044e \u0441\u0435\u043a\u0443\u043d\u0434\u044b \u043c\u043e\u0433 \u043f\u0440\u043e\u0441\u043a\u0440\u043e\u043b\u043b\u0438\u0442\u044c \u0432\u0441\u0435 \u0441\u0442\u0440\u0430\u043d\u0438\u0446\u044b \u043e\u0434\u043d\u0438\u043c \u0431\u044b\u0441\u0442\u0440\u044b\u043c \u043f\u0440\u043e\u043a\u0440\u0443\u0447\u0438\u0432\u0430\u043d\u0438\u0435\u043c \u043a\u043e\u043b\u0435\u0441\u0430 var waveBlocked = false;  var waveStartDelay = 0.2; \/\/ \u0441\u0442\u0430\u0440\u0442\u043e\u0432\u0430\u044f \u0437\u0430\u0434\u0435\u0440\u0436\u043a\u0430 \u0430\u043d\u0438\u043c\u0430\u0446\u0438\u0438  \/\/ \u0432\u0435\u0448\u0430\u0435\u043c \u043e\u0431\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a \u043d\u0430 \u043a\u043e\u043b\u0435\u0441\u043e. DOMMouseScroll \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c \u0434\u043b\u044f FireFox $(document).on(&quot;mousewheel DOMMouseScroll&quot;, function(e) {   if (waveBlocked) return;   if (e.originalEvent.wheelDelta &gt; 0 || e.originalEvent.detail &lt; 0) {     navigateWaveUp();   } else {      navigateWaveDown();   } });  $(document).on(&quot;keydown&quot;, function(e) {   if (waveBlocked) return;   if (e.which === 38) {     navigateWaveUp();   } else if (e.which === 40) {     navigateWaveDown();   } });  function navigateWaveUp() {   \/\/ \u0432 \u043e\u0442\u043b\u0438\u0447\u0438\u0438 \u043e\u0442 \u043e\u0431\u044b\u0447\u043d\u044b\u0445 navigate \u0444\u0443\u043d\u043a\u0446\u0438\u0439, \u043f\u0440\u0438 \u043f\u043e\u043f\u044b\u0442\u043a\u0435 \u0441\u043a\u0440\u043e\u043b\u043b\u0430 \u0437\u0430 \u043f\u0440\u0435\u0434\u0435\u043b\u044b \u043d\u0430\u0448\u0438\u0445 \u0441\u0442\u0440\u0430\u043d\u0438\u0446 \u043c\u044b \u043d\u0435 \u0434\u0435\u043b\u0430\u0435\u043c \u043d\u0438\u0447\u0435\u0433\u043e   \/\/ \u0438\u043d\u0430\u0447\u0435 \u0443 \u043d\u0430\u0441 \u0431\u0443\u0434\u0435\u0442 \u0441\u0442\u0430\u0440\u0442\u043e\u0432\u0430\u0442\u044c \u0431\u043b\u043e\u043a\u0438\u0440\u043e\u0432\u043a\u0430 \u0441\u043a\u0440\u043e\u043b\u043b\u0430 \u0438 \u0437\u0430\u0442\u0435\u043c \u0443\u0431\u0438\u0440\u0430\u0442\u044c\u0441\u044f \u0441 \u0437\u0430\u0434\u0435\u0440\u0436\u043a\u043e\u0439, \u0430 \u044e\u0437\u0435\u0440 \u0432\u0441\u0435 \u044d\u0442\u043e \u0432\u0440\u0435\u043c\u044f \u0431\u0443\u0434\u0435\u0442 \u0441\u043c\u043e\u0442\u0440\u0435\u0442\u044c \u043d\u0430 \u0441\u0442\u0430\u0442\u0438\u0447\u043d\u0443\u044e \u0441\u0442\u0440\u0430\u043d\u0438\u0446\u0443, \u0431\u0435\u0437 \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u043e\u0441\u0442\u0438 \u0441\u043a\u0440\u043e\u043b\u043b\u0438\u0442\u044c \u043a\u0443\u0434\u0430-\u043b\u0438\u0431\u043e   if (curPage === 1) return;   curPage--;   waveChange(); };  function navigateWaveDown() {   if (curPage === numOfPages) return;   curPage++;   waveChange(); };  function waveChange() {   waveBlocked = true; \/\/ \u0431\u043b\u043e\u043a\u0438\u0440\u0443\u0435\u043c \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u043e\u0441\u0442\u044c \u0441\u043a\u0440\u043e\u043b\u043b\u0430   var y = (curPage - 1) * winH * -1;    for (var i = 1; i &lt;= bgParts; i++) {     \/\/ \u0441\u0442\u0430\u0440\u0442\u0443\u0435\u043c \u0430\u043d\u0438\u043c\u0430\u0446\u0438\u044e \u0434\u043b\u044f \u043a\u0430\u0436\u0434\u043e\u0439 \u0433\u0440\u0443\u043f\u043f\u044b \u0447\u0430\u0441\u0442\u0435\u0439 \u0441 \u0443\u0432\u0435\u043b\u0438\u0447\u0435\u043d\u043d\u043e\u0439 \u0437\u0430\u0434\u0435\u0440\u0436\u043a\u043e\u0439, \u043f\u043e\u043c\u0438\u043c\u043e \u0441\u0442\u0430\u0442\u0438\u0447\u043d\u043e\u0439     var d = (i - 1) * waveStagger + waveStartDelay;     TweenLite.to(&quot;.ws-bg__part-&quot; + i, changeAT, {y: y, delay: d});   }    var delay = (changeAT + waveStagger * (bgParts - 1)) * 1000; \/\/ \u0441\u0447\u0438\u0442\u0430\u0435\u043c \u043e\u0431\u0449\u0435\u0435 \u0432\u0440\u0435\u043c\u044f \u0430\u043d\u0438\u043c\u0430\u0446\u0438\u0438 \u0432 \u043c\u0438\u043b\u0438\u0441\u0435\u043a\u0443\u043d\u0434\u0430\u0445   setTimeout(function() {     waveBlocked = false; \/\/ \u0443\u0431\u0438\u0440\u0430\u0435\u043c \u0431\u043b\u043e\u043a\u0438\u0440\u043e\u0432\u043a\u0443 \u0441\u043a\u0440\u043e\u043b\u043b\u0430 \u043f\u043e \u043e\u043a\u043e\u043d\u0447\u0430\u043d\u0438\u0438 \u0430\u043d\u0438\u043c\u0430\u0446\u0438\u0438     \/\/ \u043f\u0440\u043e\u0448\u0443 \u0437\u0430\u043c\u0435\u0442\u0438\u0442\u044c \u0447\u0442\u043e \u043c\u044b \u043d\u0435 \u043c\u043e\u0436\u0435\u043c \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c onComplete \u0432 gsap'e, \u0438\u0431\u043e \u043e\u043d \u0441\u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u043d\u0430 \u043a\u0430\u0436\u0434\u043e\u043c \u0448\u0430\u0433\u0435 \u0446\u0438\u043a\u043b\u0430   }, delay); }; <\/code><\/pre>\n<p>  \u0412\u0435\u0441\u044c \u043e\u0441\u043d\u043e\u0432\u043d\u043e\u0439 \u0444\u0443\u043d\u043a\u0446\u0438\u043e\u043d\u0430\u043b \u0440\u0435\u0430\u043b\u0438\u0437\u043e\u0432\u0430\u043d.<\/p>\n<h4>\u041d\u0435\u0431\u043e\u043b\u044c\u0448\u0430\u044f \u043e\u043f\u0442\u0438\u043c\u0438\u0437\u0430\u0446\u0438\u044f<\/h4>\n<p>  \u041f\u043e\u0441\u043b\u0435 \u0442\u043e\u0433\u043e \u043a\u0430\u043a \u044f \u043f\u043e\u043b\u0435\u0437 \u0441\u043c\u043e\u0442\u0440\u0435\u0442\u044c \u044d\u0442\u043e \u0434\u0435\u043c\u043e \u043d\u0430 \u0442\u0435\u043b\u0435\u0444\u043e\u043d\u0435, \u044f \u0441\u0442\u043e\u043b\u043a\u043d\u0443\u043b\u0441\u044f \u0441 \u0441\u0443\u0449\u0435\u0441\u0442\u0432\u0435\u043d\u043d\u044b\u043c\u0438 \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u0430\u043c\u0438 \u043f\u043e \u0447\u0430\u0441\u0442\u0438 \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u0434\u0438\u0442\u0435\u043b\u044c\u043d\u043e\u0441\u0442\u0438 \u0432\u043e \u0432\u0440\u0435\u043c\u044f \u0441\u0432\u0430\u0439\u043f\u0430. \u0422\u043e\u0433\u0434\u0430 \u044f \u0441\u0440\u0430\u0437\u0443 \u0432\u0441\u043f\u043e\u043c\u043d\u0438\u043b \u043e \u0442\u043e\u043c, \u0447\u0442\u043e \u043e\u0431\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a \u0434\u0432\u0438\u0436\u0435\u043d\u0438\u044f (\u0431\u0443\u0434\u044c \u0442\u043e mousemove \u0438\u043b\u0438 touchmove) \u043d\u0430\u0434\u043e \u0441\u043b\u0435\u0433\u043a\u0430 \u043e\u043f\u0442\u0438\u043c\u0438\u0437\u0438\u0440\u043e\u0432\u0430\u0442\u044c. \u0414\u043b\u044f \u044d\u0442\u043e\u0433\u043e \u044f \u0431\u0443\u0434\u0443 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c requestAnimationFrame, \u043e\u043d \u0436\u0435 rAF.<\/p>\n<div class=\"spoiler\"><b class=\"spoiler_title\">rAF? WTF?<\/b><\/p>\n<div class=\"spoiler_text\">requestAnimationFrame \u044d\u0442\u043e \u0441\u043f\u0435\u0446\u0438\u0430\u043b\u044c\u043d\u043e\u0435 \u0431\u0440\u0430\u0443\u0437\u0435\u0440\u043d\u043e\u0435 API \u0441\u043e\u0437\u0434\u0430\u043d\u043d\u043e\u0435 \u0434\u043b\u044f \u0430\u043d\u0438\u043c\u0430\u0446\u0438\u0438 \u0438 \u043f\u043e\u0434\u043e\u0431\u043d\u044b\u0445 \u0432\u0435\u0449\u0435\u0439. \u041f\u043e\u0434\u0440\u043e\u0431\u043d\u0435\u0435 <a href=\"https:\/\/developer.mozilla.org\/en-US\/docs\/Web\/API\/window\/requestAnimationFrame\">\u0442\u0443\u0442<\/a>.  <\/div>\n<\/div>\n<p>  <\/p>\n<pre><code class=\"javascript\">\/\/ \u0441\u043a\u0430\u0436\u0443 \u0447\u0435\u0441\u0442\u043d\u043e, \u044f \u043d\u0435 \u043f\u043e\u043c\u043d\u044e \u043a\u0430\u043a \u043c\u043d\u043e\u0433\u043e \u0441\u0443\u0449\u0435\u0441\u0442\u0432\u0443\u0435\u0442 \u0431\u0440\u0430\u0443\u0437\u0435\u0440\u043e\u0432, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u0434\u0440\u0443\u0436\u0430\u0442 \u0441 \u0442\u0440\u0430\u043d\u0441\u0444\u043e\u0440\u043c\u0430\u043c\u0438 \u0438 \u043d\u0435 \u0443\u043c\u0435\u044e\u0442 \u043f\u0440\u0438 \u044d\u0442\u043e\u043c \u0432 rAF \u0431\u0435\u0437 \u043f\u0440\u0435\u0444\u0438\u043a\u0441\u043e\u0432, \u0442\u0430\u043a \u0447\u0442\u043e \u043f\u0435\u0440\u0435\u0441\u0442\u0440\u0430\u0445\u043e\u0432\u044b\u0432\u0430\u0435\u043c\u0441\u044f window.requestAnimFrame = (function() {   return window.requestAnimationFrame ||     window.webkitRequestAnimationFrame ||     window.mozRequestAnimationFrame ||     function(callback){     window.setTimeout(callback, 1000 \/ 60);   }; })();  \/\/ \u043f\u0438\u0448\u0435\u043c \u043f\u0440\u043e\u0441\u0442\u0435\u043d\u044c\u043a\u0438\u0439 throttle \u0432\u0435\u043b\u043e\u0441\u0438\u043f\u0435\u0434, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0431\u0443\u0434\u0435\u0442 \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0438\u0432\u0430\u0442\u044c \u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u043e \u0432\u044b\u0437\u043e\u0432\u043e\u0432 \u0444\u0443\u043d\u043a\u0446\u0438\u0438 function rafThrottle(fn) { \/\/ \u043f\u0440\u0438\u043d\u0438\u043c\u0430\u0435\u043c \u0444\u0443\u043d\u043a\u0446\u0438\u044e \u0432 \u043a\u0430\u0447\u0435\u0441\u0442\u0432\u0435 \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u0430   var busy = false; \/\/ \u0441\u043e\u0437\u0434\u0430\u0435\u043c \u043f\u0435\u0440\u0435\u043c\u0435\u043d\u043d\u0443\u044e \u0434\u043b\u044f \u043e\u043f\u0440\u0435\u0434\u0435\u043b\u0435\u043d\u0438\u044f \u0442\u043e\u0433\u043e, \u043c\u043e\u0436\u043d\u043e \u043b\u0438 \u0432\u044b\u043f\u043e\u043b\u043d\u044f\u0442\u044c \u0444\u0443\u043d\u043a\u0446\u0438\u044e \u0438\u043b\u0438 \u0435\u0449\u0435 \u043d\u0435\u0442   return function() { \/\/ \u0432\u043e\u0437\u0432\u0440\u0430\u0449\u0430\u0435\u043c \u0444\u0443\u043d\u043a\u0446\u0438\u044e, \u043e\u0431\u0440\u0430\u0437\u0443\u044f \u043f\u0440\u0438 \u044d\u0442\u043e\u043c \u0437\u0430\u043c\u044b\u043a\u0430\u043d\u0438\u0435     if (busy) return; \/\/ \u0435\u0441\u043b\u0438 \u0437\u0430\u043d\u044f\u0442\u043e, \u0442\u043e \u0440\u0430\u0437\u0432\u043e\u0440\u0430\u0447\u0438\u0432\u0430\u0435\u043c\u0441\u044f \u0438 \u0443\u0445\u043e\u0434\u0438\u043c     busy = true; \/\/ \u0432\u0435\u0448\u0430\u0435\u043c \u0442\u0430\u0431\u043b\u0438\u0447\u043a\u0443 \u0447\u0442\u043e \u0437\u0430\u043d\u044f\u0442\u043e     fn.apply(this, arguments); \/\/ \u0432\u044b\u0437\u044b\u0432\u0430\u0435\u043c \u0444\u0443\u043d\u043a\u0446\u0438\u044e      \/\/ \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u043c rAF, \u0434\u043b\u044f \u0442\u043e\u0433\u043e \u0447\u0442\u043e\u0431\u044b \u0441\u043d\u044f\u0442\u044c \u0442\u0430\u0431\u043b\u0438\u0447\u043a\u0443, \u043a\u043e\u0433\u0434\u0430 \u0431\u0440\u0430\u0443\u0437\u0435\u0440\u0443 \u043f\u043e\u043b\u0435\u0433\u0447\u0430\u0435\u0442     requestAnimFrame(function() {       busy = false;     });   }; };  \/\/\u043e\u0431\u043e\u0440\u0430\u0447\u0438\u0432\u0430\u0435\u043c \u043d\u0430\u0448 \u043e\u0431\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a mousemove \u0432 rafThrottle var mousemoveHandler = rafThrottle(function(e) {   \/\/ \u0442\u043e\u0442 \u0436\u0435 \u043a\u043e\u0434 \u0444\u0443\u043d\u043a\u0446\u0438\u0438 }); <\/code><\/pre>\n<p>  \u042d\u0442\u0430 \u043e\u043f\u0442\u0438\u043c\u0438\u0437\u0430\u0446\u0438\u044f \u0434\u0430\u043b\u0430 \u0437\u0430\u043c\u0435\u0442\u043d\u044b\u0439 \u043f\u0440\u0438\u0440\u043e\u0441\u0442 \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u0434\u0438\u0442\u0435\u043b\u044c\u043d\u043e\u0441\u0442\u0438 \u043d\u0430 \u043c\u043e\u0435\u043c Nexus 5, \u0442\u0430\u043a \u043a\u0430\u043a \u043e\u043d\u0430 \u0441\u043d\u0438\u0437\u0438\u043b\u0430 \u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u043e \u0432\u044b\u0447\u0438\u0441\u043b\u0435\u043d\u0438\u0439 \u0438 \u043f\u0435\u0440\u0435\u0437\u0430\u043f\u0443\u0441\u043a\u043e\u0432 \u0430\u043d\u0438\u043c\u0430\u0446\u0438\u0438 \u043f\u0440\u0438 \u043f\u043e\u0441\u0442\u043e\u044f\u043d\u043d\u043e\u043c \u0434\u0432\u0438\u0436\u0435\u043d\u0438\u0438 \u043c\u044b\u0448\u0438\/\u043f\u0430\u043b\u044c\u0446\u0430. \u0414\u0430 \u0438 \u043d\u0430 \u0434\u0435\u0441\u043a\u0442\u043e\u043f\u0435 \u0442\u043e\u0436\u0435 \u043f\u043e \u0432\u0438\u0434\u0443 \u0432\u0441\u0435 \u0441\u0442\u0430\u043b\u043e \u043f\u043e\u043b\u0443\u0447\u0448\u0435 \u0440\u0430\u0431\u043e\u0442\u0430\u0442\u044c (\u0445\u043e\u0442\u044f \u0438 \u0434\u043e \u044d\u0442\u043e\u0433\u043e \u043d\u0435 \u0431\u044b\u043b\u043e \u043f\u0440\u043e\u0431\u043b\u0435\u043c, \u043f\u0440\u0438 \u0443\u0447\u0435\u0442\u0435 \u0447\u0442\u043e \u0431\u0440\u0430\u0443\u0437\u0435\u0440 \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u0441\u043e \u0432\u0441\u0442\u0440\u043e\u0435\u043d\u043d\u043e\u0439 \u0432\u0438\u0434\u0435\u043e\u043a\u0430\u0440\u0442\u044b).<\/p>\n<p>  \u041a\u0430\u043a \u0440\u0435\u0430\u043b\u0438\u0437\u043e\u0432\u0430\u043d\u044b \u0442\u0435\u043a\u0441\u0442\u043e\u0432\u044b\u0435 \u0437\u0430\u0433\u043e\u043b\u043e\u0432\u043a\u0438 \u044f \u0440\u0430\u0441\u043f\u0438\u0441\u044b\u0432\u0430\u0442\u044c \u043d\u0435 \u0431\u0443\u0434\u0443, \u0442\u0430\u043c \u0432\u0441\u0435 \u0434\u043e\u0432\u043e\u043b\u044c\u043d\u043e-\u0442\u0430\u043a\u0438 \u043f\u0440\u043e\u0441\u0442\u043e, \u0447\u0442\u0435\u043d\u0438\u0435 \u043a\u043e\u0434\u0430 \u0432\u0430\u043c \u0432 \u043f\u043e\u043c\u043e\u0449\u044c.<\/p>\n<p>  \u0412\u043e\u0442 \u0432 \u043e\u0431\u0449\u0435\u043c \u0442\u043e \u0438 \u0432\u0441\u0435! \u0421\u0441\u044b\u043b\u043a\u0438 \u043d\u0430 \u0434\u0435\u043c\u043e:<\/p>\n<p>  \u0412\u0435\u0440\u0441\u0438\u044f <a href=\"http:\/\/codepen.io\/suez\/pen\/wMOVXz\">\u0441 \u0440\u0435\u0434\u0430\u043a\u0442\u043e\u0440\u043e\u043c<\/a>.<br \/>  <a href=\"http:\/\/s.codepen.io\/suez\/debug\/wMOVXz\">\u0424\u0443\u043b\u043b\u0441\u043a\u0440\u0438\u043d \u0432\u0435\u0440\u0441\u0438\u044f \u0431\u0435\u0437 \u0430\u0439\u0444\u0440\u0435\u0439\u043c\u0430 \u0438 \u043a\u0443\u0441\u043a\u043e\u0432 \u043a\u043e\u0434\u043f\u0435\u043d\u0430<\/a> \u2014 \u0435\u0441\u043b\u0438 \u0445\u043e\u0442\u0438\u0442\u0435 \u043f\u0440\u043e\u0432\u0435\u0440\u044f\u0442\u044c \u043d\u0430 \u0442\u0435\u043b\u0435\u0444\u043e\u043d\u0435, \u0442\u043e \u043e\u0442\u043a\u0440\u044b\u0432\u0430\u0439\u0442\u0435 \u044d\u0442\u0443 \u0432\u0435\u0440\u0441\u0438\u044e, \u0434\u0440\u0443\u0433\u0438\u0435 \u0431\u0430\u0433\u0430\u044e\u0442 \u043d\u0430 \u0442\u0430\u0447-\u0443\u0441\u0442\u0440\u043e\u0439\u0441\u0442\u0432\u0430\u0445.<\/p>\n<div class=\"spoiler\"><b class=\"spoiler_title\">\u0422\u0430\u043a, \u0441\u0442\u043e\u043f, \u0430 \u043a\u043e\u0434 \u0434\u043b\u044f \u0442\u0430\u0447-\u0443\u0441\u0442\u0440\u043e\u0439\u0441\u0442\u0432?<\/b><\/p>\n<div class=\"spoiler_text\">\u0412 \u043e\u0440\u0438\u0433\u0438\u043d\u0430\u043b\u044c\u043d\u043e\u043c \u0434\u0435\u043c\u043e \u0440\u0435\u0430\u043b\u0438\u0437\u043e\u0432\u0430\u043d\u0430 \u043f\u043e\u0434\u0434\u0435\u0440\u0436\u043a\u0430 \u0442\u0430\u0447 \u0443\u0441\u0442\u0440\u043e\u0439\u0441\u0442\u0432. \u0422\u0430\u043c \u043f\u043e \u0441\u0443\u0442\u0438 \u0434\u0435\u043b\u0430 \u0434\u043e\u0431\u0430\u0432\u043b\u044f\u0435\u0442\u0441\u044f \u043b\u0438\u0448\u044c \u0434\u043e\u043f\u043e\u043b\u043d\u0438\u0442\u0435\u043b\u044c\u043d\u044b\u0439 \u043e\u0431\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a \u043d\u0430 touchmove, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0434\u0435\u043b\u0430\u0435\u0442 \u0442\u0435 \u0436\u0435 \u0432\u0435\u0449\u0438 \u0438 \u0435\u0449\u0435 \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u0441\u0442\u0440\u043e\u0447\u0435\u043a \u043a\u043e\u0434\u0430, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043b\u0435\u0433\u043a\u043e \u043d\u0430\u0439\u0442\u0438. \u041d\u043e \u044f \u0440\u0435\u0448\u0438\u043b \u043d\u0435 \u043e\u043f\u0438\u0441\u044b\u0432\u0430\u0442\u044c \u044d\u0442\u0443 \u0447\u0430\u0441\u0442\u044c \u0432 \u0441\u0442\u0430\u0442\u044c\u0435, \u043f\u043e\u0442\u043e\u043c\u0443-\u0447\u0442\u043e \u0434\u0430\u0436\u0435 \u043f\u043e\u0441\u043b\u0435 \u043e\u043f\u0442\u0438\u043c\u0438\u0437\u0430\u0446\u0438\u0438 \u043c\u043e\u0435 \u0434\u0435\u043c\u043e \u0441\u0443\u0449\u0435\u0441\u0442\u0432\u0435\u043d\u043d\u043e \u043f\u0440\u043e\u0438\u0433\u0440\u044b\u0432\u0430\u0435\u0442 \u043f\u043e \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u0434\u0438\u0442\u0435\u043b\u044c\u043d\u043e\u0441\u0442\u0438 \u043d\u0430 \u0442\u0435\u043b\u0435\u0444\u043e\u043d\u0430\u0445 (\u043a\u0430\u043a \u043c\u0438\u043d\u0438\u043c\u0443\u043c \u043d\u0430 \u043c\u043e\u0435\u043c Nexus 5) \u043e\u0440\u0438\u0433\u0438\u043d\u0430\u043b\u044c\u043d\u043e\u043c\u0443 \u0441\u0430\u0439\u0442\u0443, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u043d\u0430 \u043a\u0430\u043d\u0432\u0430\u0441\u0435. \u0425\u043e\u0442\u044f \u044d\u0442\u043e \u0432\u0441\u0435 \u0440\u0430\u0432\u043d\u043e \u043d\u0435\u043f\u043b\u043e\u0445\u043e\u0439 \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442 \u0434\u043b\u044f \u0442\u0430\u043a\u043e\u0433\u043e \u044d\u0444\u0444\u0435\u043a\u0442\u0430.<br \/>  \u0418 \u043a \u0442\u043e\u043c\u0443 \u0436\u0435 \u043d\u0430 \u043c\u043e\u0431\u0438\u043b\u044c\u043d\u044b\u0445 \u0443\u0441\u0442\u0440\u043e\u0439\u0441\u0442\u0432\u0430\u0445 \u0438\u043c\u0435\u044e\u0442\u0441\u044f \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u044b \u0441 \u0447\u0435\u0440\u043d\u044b\u043c\u0438 \u043f\u043e\u043b\u043e\u0441\u0430\u043c\u0438 \u043f\u043e \u043a\u0440\u0430\u044f\u043c \u0447\u0430\u0441\u0442\u0435\u0439 \u0444\u043e\u043d\u0430 \u0432\u043e \u0432\u0440\u0435\u043c\u044f \u0434\u0432\u0438\u0436\u0435\u043d\u0438\u044f. \u0421\u0432\u044f\u0437\u0430\u043d\u043e \u044d\u0442\u043e \u0441 \u0448\u0438\u0440\u0438\u043d\u043e\u0439 \u0432 % \u0438 \u0441\u043e\u0447\u0435\u0442\u0430\u043d\u0438\u0435\u043c 3\u0434 \u0442\u0440\u0430\u043d\u0441\u0444\u043e\u0440\u043c\u0430\u0446\u0438\u0439 \u0432\u043e \u0432\u0440\u0435\u043c\u044f \u0434\u0432\u0438\u0436\u0435\u043d\u0438\u044f, \u0438\u0437-\u0437\u0430 \u0447\u0435\u0433\u043e \u0441\u043b\u0435\u0433\u043a\u0430 \u0438\u0437\u043c\u0435\u043d\u044f\u044e\u0442\u0441\u044f \u0440\u0430\u0437\u043c\u0435\u0440\u044b \u0447\u0430\u0441\u0442\u0435\u0439 \u0438 \u043f\u0440\u043e\u0441\u0432\u0435\u0447\u0438\u0432\u0430\u044e\u0442 \u043a\u0443\u0441\u043a\u0438 \u0447\u0435\u0440\u043d\u043e\u0433\u043e \u0444\u043e\u043d\u0430 body.  <\/div>\n<\/div>\n<p>  <\/p>\n<div class=\"spoiler\"><b class=\"spoiler_title\">\u041d\u0430\u043f\u043e\u0441\u043b\u0435\u0434\u043e\u043a<\/b><\/p>\n<div class=\"spoiler_text\">\u042d\u0442\u043e \u043c\u043e\u044f \u043f\u0435\u0440\u0432\u0430\u044f \u0441\u0442\u0430\u0442\u044c\u044f, \u0442\u0430\u043a \u0447\u0442\u043e \u043a\u0430\u0447\u0435\u0441\u0442\u0432\u043e \u0441\u0438\u043b\u044c\u043d\u043e \u0445\u0440\u043e\u043c\u0430\u0435\u0442. \u0414\u0430 \u0438 \u0434\u0435\u043c\u043e \u044f\u0432\u043d\u043e \u043d\u0435 \u043e\u0434\u043d\u043e \u0438\u0437 \u043b\u0443\u0447\u0448\u0438\u0445. \u041d\u043e \u043f\u0438\u0441\u0430\u0442\u044c \u0440\u0435\u0448\u0438\u043b \u043e\u0431 \u044d\u0442\u043e\u0439 \u0434\u0435\u043c\u043a\u0435, \u0438\u0431\u043e \u0441\u0434\u0435\u043b\u0430\u043b \u044f \u0435\u0451 \u0432\u0441\u0435\u0433\u043e 10 \u0434\u043d\u0435\u0439 \u043d\u0430\u0437\u0430\u0434 \u0438 \u043d\u0435\u043f\u043b\u043e\u0445\u043e \u043f\u043e\u043c\u043d\u044e \u0445\u043e\u0434 \u0441\u0432\u043e\u0438\u0445 \u043c\u044b\u0441\u043b\u0435\u0439.  <\/div>\n<\/div>\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=\"https:\/\/habrahabr.ru\/post\/278181\/\"> https:\/\/habrahabr.ru\/post\/278181\/<\/a><\/p>\n","protected":false},"excerpt":{"rendered":"<p>       \u0412 \u044d\u0442\u043e\u0439 \u0441\u0442\u0430\u0442\u044c\u0435 \u044f \u043f\u043e\u0441\u0442\u0430\u0440\u0430\u044e\u0441\u044c \u0434\u043e\u0445\u043e\u0434\u0447\u0438\u0432\u043e \u0440\u0430\u0441\u0441\u043a\u0430\u0437\u0430\u0442\u044c \u043e \u043f\u0440\u043e\u0446\u0435\u0441\u0441\u0435 \u0441\u043e\u0437\u0434\u0430\u043d\u0438\u044f <a href=\"http:\/\/codepen.io\/suez\/full\/wMOVXz\">\u0434\u0435\u043c\u043a\u0438 Wavescroll<\/a>.<\/p>\n<p>  <img decoding=\"async\" src=\"http:\/\/i.imgur.com\/MXoOiZM.jpg\" alt=\"image\"\/>  <\/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-275132","post","type-post","status-publish","format-standard","hentry"],"_links":{"self":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/275132","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=275132"}],"version-history":[{"count":0,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/275132\/revisions"}],"wp:attachment":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=275132"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=275132"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=275132"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}