{"id":243343,"date":"2014-11-17T01:12:02","date_gmt":"2014-11-16T21:12:02","guid":{"rendered":"http:\/\/savepearlharbor.com\/?p=243343"},"modified":"-0001-11-30T00:00:00","modified_gmt":"-0001-11-29T21:00:00","slug":"","status":"publish","type":"post","link":"https:\/\/savepearlharbor.com\/?p=243343","title":{"rendered":"<span class=\"post_title\">\u041d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u0438\u043d\u0442\u0435\u0440\u0435\u0441\u043d\u043e\u0441\u0442\u0435\u0439 \u0438 \u043f\u043e\u043b\u0435\u0437\u043d\u043e\u0441\u0442\u0435\u0439 \u0434\u043b\u044f \u0432\u0435\u0431-\u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a\u0430 #33<\/span>"},"content":{"rendered":"<div class=\"content html_format\">     \t\u0414\u043e\u0431\u0440\u043e\u0433\u043e \u0432\u0440\u0435\u043c\u0435\u043d\u0438 \u0441\u0443\u0442\u043e\u043a, \u0443\u0432\u0430\u0436\u0430\u0435\u043c\u044b\u0435 \u0445\u0430\u0431\u0440\u0430\u0432\u0447\u0430\u043d\u0435. \u0417\u0430 \u043f\u043e\u0441\u043b\u0435\u0434\u043d\u0435\u0435 \u0432\u0440\u0435\u043c\u044f \u044f \u0443\u0432\u0438\u0434\u0435\u043b \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u0438\u043d\u0442\u0435\u0440\u0435\u0441\u043d\u044b\u0445 \u0438 \u043f\u043e\u043b\u0435\u0437\u043d\u044b\u0445 \u0438\u043d\u0441\u0442\u0440\u0443\u043c\u0435\u043d\u0442\u043e\u0432\/\u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\/\u0441\u043e\u0431\u044b\u0442\u0438\u0439, \u043a\u043e\u0442\u043e\u0440\u044b\u043c\u0438 \u0445\u043e\u0447\u0443 \u043f\u043e\u0434\u0435\u043b\u0438\u0442\u044c\u0441\u044f \u0441 \u0425\u0430\u0431\u0440\u043e\u043c. <\/p>\n<h4><a href=\"https:\/\/github.com\/ConnorAtherton\/walkway\">Walkway.js<\/a> \u0438 <a href=\"https:\/\/github.com\/maxwellito\/vivus\">Vivus.js<\/a><\/h4>\n<p>  <img decoding=\"async\" src=\"\/\/habrastorage.org\/files\/881\/211\/b22\/881211b225a44bfeab32d862d97a7551.jpg\"\/><br \/>  \u0412\u044b \u0432\u0438\u0434\u0435\u043b\u0438 <a href=\"http:\/\/www.polygon.com\/a\/ps4-review\/video_review\">\u044d\u0442\u043e\u0442 \u0432\u0435\u043b\u0438\u043a\u043e\u043b\u0435\u043f\u043d\u044b\u0439 \u043b\u044d\u043d\u0434\u0438\u043d\u0433<\/a> \u043f\u043e\u0441\u0432\u044f\u0449\u0435\u043d\u043d\u044b\u0439 \u0430\u043d\u043e\u043d\u0441\u0443 Sony PlayStation 4? \u041e\u0431\u0440\u0430\u0442\u0438\u0442\u0435 \u0432\u043d\u0438\u043c\u0430\u043d\u0438\u0435 \u043d\u0430 \u0430\u043d\u0438\u043c\u0430\u0446\u0438\u044e SVG \u043e\u0431\u044a\u0435\u043a\u0442\u043e\u0432 \u0441\u043e\u0441\u0442\u043e\u044f\u0449\u0438\u0445 \u0438\u0437 \u043a\u043e\u043d\u0442\u0443\u0440\u043e\u0432. \u041e\u043d\u0438 \u0441\u043b\u043e\u0432\u043d\u043e \u0440\u0438\u0441\u0443\u044e\u0442\u0441\u044f \u0445\u0443\u0434\u043e\u0436\u043d\u0438\u043a\u043e\u043c \u0432 \u0440\u0435\u0436\u0438\u043c\u0435 \u0440\u0435\u0430\u043b\u044c\u043d\u043e\u0433\u043e \u0432\u0440\u0435\u043c\u0435\u043d\u0438. \u041e\u0442\u043d\u044b\u043d\u0435 \u044d\u0442\u043e\u0442 \u044d\u0444\u0444\u0435\u043a\u0442 \u043c\u043e\u0436\u043d\u043e \u043b\u0435\u0433\u043a\u043e \u043f\u043e\u0432\u0442\u043e\u0440\u0438\u0442\u044c \u0441 \u043f\u043e\u043c\u043e\u0449\u044c\u044e Walkway \u0438 Vivus. \u041e\u0431\u0435 \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0438 \u043c\u0430\u043a\u0441\u0438\u043c\u0430\u043b\u044c\u043d\u043e \u043f\u0440\u043e\u0441\u0442\u044b \u0432 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u0438 \u0438 \u043f\u0440\u0438\u043c\u0435\u043d\u0438\u043c\u044b \u0442\u043e\u043b\u044c\u043a\u043e \u0434\u043b\u044f <b>path<\/b> \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u043e\u0432, \u043f\u043e\u0441\u043a\u043e\u043b\u044c\u043a\u0443 \u043f\u0440\u0438\u043d\u0446\u0438\u043f \u0438\u0445 \u0440\u0430\u0431\u043e\u0442\u044b \u043e\u0441\u043d\u043e\u0432\u044b\u0432\u0430\u0435\u0442\u0441\u044f \u043d\u0430 \u0432\u0437\u0430\u0438\u043c\u043e\u0434\u0435\u0439\u0441\u0442\u0432\u0438\u0438 \u0441 CSS \u0441\u0432\u043e\u0439\u0441\u0442\u0432\u043e\u043c <b>strokeDashoffset<\/b>. \u0425\u043e\u0442\u044c \u0438 \u0443 Walkway \u0437\u043d\u0430\u0447\u0438\u0442\u0435\u043b\u044c\u043d\u043e \u0431\u043e\u043b\u044c\u0448\u0435 \u0437\u0432\u0435\u0437\u0434 \u043d\u0430 \u0413\u0438\u0442\u0445\u0430\u0431\u0435, \u0437\u0430\u0442\u043e Vivus \u043f\u0440\u0435\u0434\u043e\u0441\u0442\u0430\u0432\u043b\u044f\u0435\u0442 \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u0432\u0430\u0440\u0438\u0430\u043d\u0442\u043e\u0432 \u043e\u0442\u0440\u0438\u0441\u043e\u0432\u043a\u0438: Delayed, Async \u0438 OneByOne.<\/p>\n<pre><code class=\"javascript\">\/\/Walkway var svg = new Walkway('#test');  svg.draw(function() {   console.log('Animation finished'); });  \/\/Vivus new Vivus('my-svg-id', {type: 'delayed', duration: 200}, myCallback); <\/code><\/pre>\n<p>  <a name=\"habracut\"><\/a><br \/>  <a href=\"https:\/\/github.com\/taye\/interact.js\">Interact.js<\/a><br \/>  \u041f\u043e\u0442\u0440\u044f\u0441\u0430\u044e\u0449\u0430\u044f \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0430 \u0434\u043b\u044f \u0440\u0430\u0431\u043e\u0442\u044b \u0441 \u0442\u044f\u043d\u0438-\u0431\u0440\u043e\u0441\u0430\u0439, \u0440\u0435\u0441\u0430\u0439\u0437\u043e\u043c \u0438 \u0436\u0435\u0441\u0442\u0430\u043c\u0438. \u041c\u0435\u0433\u0430 \u043a\u0440\u0443\u0442\u043e \u0435\u0449\u0435 \u0442\u043e, \u0447\u0442\u043e Interact \u043f\u043e\u0437\u0432\u043e\u043b\u044f\u0435\u0442 \u0442\u0430\u0441\u043a\u0430\u0442\u044c SVG \u0438 \u043a\u043b\u044e\u0447\u0435\u0432\u044b\u0435 \u0442\u043e\u0447\u043a\u0438 \u0432 SVG \u043e\u0431\u044a\u0435\u043a\u0442\u0430\u0445. \u0420\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u0432\u043e \u0432\u0441\u0435\u0445 \u0441\u043e\u0432\u0440\u0435\u043c\u0435\u043d\u043d\u044b\u0445 \u0431\u0440\u0430\u0443\u0437\u0435\u0440\u0430\u0445: Chrome, Firefox, Opera \u0438 Internet Explorer 8+ \u0438 \u043f\u043e\u0434\u0434\u0435\u0440\u0436\u0438\u0432\u0430\u0435\u0442 \u043c\u043e\u0431\u0438\u043b\u044c\u043d\u044b\u0435 \u0443\u0441\u0442\u0440\u043e\u0439\u0441\u0442\u0432\u0430. \u041d\u0435 \u0437\u0430\u0432\u0438\u0441\u0438\u0442 \u043e\u0442 \u0441\u0442\u043e\u0440\u043e\u043d\u043d\u0438\u043a \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a. \u041c\u043e\u0449\u043d\u044b\u0439 API \u0438 \u0441\u043e\u0431\u044b\u0442\u0438\u0439\u043d\u0430\u044f \u043c\u043e\u0434\u0435\u043b\u044c. \u041a\u043e\u043c\u043f\u0430\u043a\u0442\u043d\u043e\u0435 \u0440\u0435\u0448\u0435\u043d\u0438\u0435 \u043d\u0430 \u0437\u0430\u043c\u0435\u043d\u0443 \u043e\u0431\u044a\u0435\u043c\u043d\u044b\u0445 jQuery + jQuery UI. <\/p>\n<pre><code class=\"javascript\">var \/\/ x and y to keep the position that's been dragged to     x = 0,     y = 0,     \/\/ vendor prefixes (prefices?)     transformProp = 'transform' in document.body.style?                 'transform': 'webkitTransform' in document.body.style?                     'webkitTransform': 'mozTransform' in document.body.style?                         'mozTransform': 'oTransform' in document.body.style?                             'oTransform': 'msTransform';  \/\/ make an Interactable of the document body element interact(document.body)     \/\/ make a draggable of the Interactable     .draggable({         \/\/ on(drag)move         \/\/ could also have done interact(document.body).draggable(true).ondragmove = function...         onmove: function (event) {             x += event.dx;             y += event.dy;              \/\/ translate the document body by the change in pointer position             document.body.style[transformProp] = 'translate(' + x + 'px, ' + y + 'px)';         }     })     \/\/ you should really add listeners like this if you want to add multiple listeners     .on('dragend', function (event) {         console.log('dragged a distance of ' +              Math.sqrt(event.dx*event.dx + event.dy*event.dy) +              ' pixels to ' + event.pageX + ', ' + event.pageY);     })     \/\/ allow inertia throwing     .inertia({         resistance: 15,         zeroResumeDelta: true     });     \/\/ snap to the corners of the specified grid     .snap({         mode: 'grid',         grid: {             x: 100,             y: 5         },         gridOffset: {             x: 20,             y: 10         },         range: Infinity \/\/ can also use -1 which gets changed to Infinity     });   \/\/ you can also listen to InteractEvents for every Interactable interact.on('dragstart', function (event) {     console.log('starting drag from ' + event.x0 + ', ' + event.y0); }); <\/code><\/pre>\n<h4><a href=\"https:\/\/github.com\/Dogfalo\/materialize\">Materialize<\/a> \u0438 <a href=\"https:\/\/github.com\/callemall\/material-ui\">Material UI<\/a><\/h4>\n<p>  <img decoding=\"async\" src=\"\/\/habrastorage.org\/files\/600\/27d\/1e2\/60027d1e2c54480992a5da582703e696.jpg\"\/><br \/>  \u041d\u0435\u0434\u0430\u0432\u043d\u043e \u043c\u043d\u0435 \u043f\u043e\u0432\u0441\u0442\u0440\u0435\u0447\u0430\u043b\u0438\u0441\u044c \u0434\u0432\u0430 \u0441\u0430\u043c\u043e\u0434\u043e\u0441\u0442\u0430\u0442\u043e\u0447\u043d\u044b\u0445 \u0444\u0440\u0435\u0439\u043c\u0432\u043e\u0440\u043a\u0430, \u0433\u0434\u0435 \u0432\u0441\u0435 \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u044b \u0438 \u044d\u0444\u0444\u0435\u043a\u0442\u044b \u043d\u0430\u0441\u043b\u0435\u0434\u0443\u044e\u0442 \u0441\u0442\u0438\u043b\u0438\u0441\u0442\u043a\u0443 \u043f\u043e\u043f\u0443\u043b\u044f\u0440\u043d\u043e\u0433\u043e Google Material Design. Materialize \u0431\u043e\u043b\u0435\u0435 \u0431\u043e\u0433\u0430\u0442 \u0440\u0430\u0437\u043b\u0438\u0447\u043d\u044b\u043c\u0438 \u0438\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441\u043d\u044b\u043c\u0438 \u0440\u0435\u0448\u0435\u043d\u0438\u044f\u043c\u0438, \u0430 Material UI \u043f\u0440\u0435\u0434\u0441\u0442\u0430\u0432\u043b\u044f\u0435\u0442 \u0438\u0437 \u0441\u0435\u0431\u044f \u043d\u0430\u0431\u043e\u0440 React \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u043e\u0432. <\/p>\n<h4><a href=\"http:\/\/jsfiddle.net\/osfnzyfd\/\">450 lines language implementation<\/a><\/h4>\n<p>  \u0412\u044b \u043f\u043e\u043c\u043d\u0438\u0442\u0435 \u0442\u0440\u0435\u043d\u0434\u043e\u0432\u0443\u044e \u043d\u0435\u0434\u0435\u043b\u044e \u043d\u0435\u043d\u043e\u0440\u043c\u0430\u043b\u044c\u043d\u043e\u0433\u043e \u043f\u0440\u043e\u0433\u0440\u0430\u043c\u043c\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u044f \u043d\u0430 \u0425\u0430\u0431\u0440\u0435 \u0433\u043e\u0434 \u043d\u0430\u0437\u0430\u0434? <a href=\"http:\/\/habrahabr.ru\/post\/202476\/\">\u041a\u0440\u043e\u0448\u0435\u0447\u043d\u0430\u044f \u0437\u043c\u0435\u0439\u043a\u0430 \u043d\u0430 JavaScript (30 \u0441\u0442\u0440\u043e\u043a \u043a\u043e\u0434\u0430)<\/a>, <a href=\"http:\/\/habrahabr.ru\/post\/202304\/\">\u041a\u0440\u043e\u0448\u0435\u0447\u043d\u044b\u0439 Excel \u043d\u0430 \u0447\u0438\u0441\u0442\u043e\u043c JavaScript (30 \u0441\u0442\u0440\u043e\u043a \u043a\u043e\u0434\u0430)<\/a> (<a href=\"http:\/\/habrahabr.ru\/sandbox\/74814\/\">\u0438 \u0434\u0430\u0436\u0435 5 \u0441\u0442\u0440\u043e\u043a \u043e\u0442 \u0414\u044d\u0432\u0438\u0434\u0430 \u0411\u043b\u0435\u0439\u043d\u0430<\/a>), <a href=\"http:\/\/habrahabr.ru\/post\/202628\/\">Tetris <\/a>, <a href=\"http:\/\/habrahabr.ru\/post\/202530\/\">\u0410\u0440\u043a\u0430\u043d\u043e\u0438\u0434<\/a>, <a href=\"http:\/\/habrahabr.ru\/post\/202556\/\">\u0413\u043e\u043d\u043e\u0447\u043a\u0430<\/a>, <a href=\"http:\/\/habrahabr.ru\/post\/202646\/\">\u041f\u0438\u0430\u043d\u0438\u043d\u043e<\/a>, <a href=\"http:\/\/habrahabr.ru\/post\/202684\/\">Roguelike\/RPG<\/a>, <a href=\"http:\/\/habrahabr.ru\/post\/202756\/\">\u0421\u043e\u043a\u043e\u0431\u0430\u043d<\/a>, <a href=\"http:\/\/habrahabr.ru\/sandbox\/74692\/\">\u0425\u0430\u043d\u043e\u0439\u0441\u043a\u0430\u044f \u0431\u0430\u0448\u043d\u044f<\/a>, <a href=\"http:\/\/habrahabr.ru\/sandbox\/74604\/\">\u041a\u0440\u0435\u0441\u0442\u0438\u043a\u0438 \u043d\u043e\u043b\u0438\u043a\u0438<\/a>, <a href=\"http:\/\/habrahabr.ru\/sandbox\/74716\/\">\u041f\u044f\u0442\u043d\u0430\u0448\u043a\u0438<\/a>, \u0421\u0430\u043f\u0435\u0440 (<a href=\"http:\/\/habrahabr.ru\/post\/202758\/\">1<\/a> \u0438 <a href=\"http:\/\/habrahabr.ru\/post\/202750\/\">2<\/a>), <a href=\"http:\/\/habrahabr.ru\/post\/202852\/\">\u0426\u0432\u0435\u0442\u043e\u0432\u0430\u044f \u043f\u0438\u043f\u0435\u0442\u043a\u0430 \u043d\u0430 JS, 399 \u0441\u0438\u043c\u0432\u043e\u043b\u043e\u0432 (\u043d\u0435 \u0441\u0442\u0440\u043e\u043a)<\/a>, <a href=\"http:\/\/habrahabr.ru\/post\/203478\/\">\u0413\u0435\u043d\u0435\u0440\u0430\u0446\u0438\u044f \u043b\u0430\u0431\u0438\u0440\u0438\u043d\u0442\u043e\u0432 \u0430\u043b\u0433\u043e\u0440\u0438\u0442\u043c\u043e\u043c \u042d\u0439\u043b\u0435\u0440\u0430<\/a>, <a href=\"http:\/\/habrahabr.ru\/post\/207964\/\">\u0418\u0433\u0440\u0430 \u0432 30 \u043a\u043e\u043c\u0430\u043d\u0434 \u0410\u0441\u0441\u0435\u043c\u0431\u043b\u0435\u0440\u0430<\/a>, <a href=\"http:\/\/habrahabr.ru\/post\/202840\/\">Minecraft \u043d\u0430 C# (19 \u0441\u0442\u0440\u043e\u043a \u043a\u043e\u0434\u0430)<\/a>, <a href=\"http:\/\/habrahabr.ru\/post\/202678\/\">\u0420\u0438\u0441\u043e\u0432\u0430\u043b\u043a\u0430 \u043f\u043e\u0434 Windows \u043d\u0430 C++ (30+ \u0441\u0442\u0440\u043e\u043a \u043a\u043e\u0434\u0430)<\/a> \u0438 \u043c\u043e\u044f \u043b\u044e\u0431\u0438\u043c\u0430\u044f \u0445\u0438\u0442\u0440\u043e\u0441\u0442\u044c <a href=\"http:\/\/habrahabr.ru\/post\/203048\/\">\u0418\u0433\u0440\u0430 \u0432 0 \u0441\u0442\u0440\u043e\u043a \u043a\u043e\u0434\u0430 \u043d\u0430 \u0447\u0438\u0441\u0442\u043e\u043c JS<\/a>. \u041f\u0440\u0438\u043c\u0435\u0440 \u0441\u0432\u043e\u0435\u0433\u043e \u044f\u0437\u044b\u043a\u0430 \u043f\u0440\u043e\u0433\u0440\u0430\u043c\u043c\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u044f \u0437\u0430 450 \u0441\u0442\u0440\u043e\u043a \u043d\u0435 \u043f\u043b\u043e\u0445\u043e\u0435 \u0434\u043e\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u0435 \u043a \u044d\u0442\u043e\u0439 \u043f\u043e\u0434\u0431\u043e\u0440\u043a\u0435 <s>\u0432 \u044d\u0442\u043e\u0439 \u043f\u043e\u0434\u0431\u043e\u0440\u043a\u0435<\/s>. <\/p>\n<h4><a href=\"https:\/\/github.com\/VincentGarreau\/particles.js\">Particles.js<\/a><\/h4>\n<p>  <a href=\"https:\/\/github.com\/VincentGarreau\/particles.js\"><img decoding=\"async\" src=\"\/\/habrastorage.org\/files\/d03\/31f\/72d\/d0331f72dddb468e81c25701ffcf381c.jpg\"\/><\/a><br \/>  \u041f\u0440\u043e\u0441\u0442\u0430\u044f \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0430 \u0434\u043b\u044f \u0441\u043e\u0437\u0434\u0430\u043d\u0438\u044f \u00ab\u0436\u0438\u0432\u044b\u0445 \u0447\u0430\u0441\u0442\u0438\u0446\u00bb. \u0418\u043c\u0435\u0435\u0442 \u0446\u0435\u043b\u044b\u0439 \u0440\u044f\u0434 \u0440\u0430\u0437\u043b\u0438\u0447\u043d\u044b\u0445 \u043e\u043f\u0446\u0438\u0439 \u0438 \u043f\u043e\u0437\u0432\u043e\u043b\u0438\u0442 \u0432\u0430\u043c \u0441\u043e\u0442\u0432\u043e\u0440\u0438\u0442\u044c \u043f\u0440\u0438\u044f\u0442\u043d\u043e\u0435 \u0443\u043a\u0440\u0430\u0448\u0435\u043d\u0438\u0435 \u0434\u043b\u044f \u0432\u0430\u0448\u0435\u0433\u043e \u0444\u043e\u043d\u0430. <\/p>\n<pre><code class=\"javascript\">particlesJS('particles-js', {   particles: {     color: '#fff',     shape: 'circle', \/\/ &quot;circle&quot;, &quot;edge&quot; or &quot;triangle&quot;     opacity: 1,     size: 4,     size_random: true,     nb: 150,     line_linked: {       enable_auto: true,       distance: 100,       color: '#fff',       opacity: 1,       width: 1,       condensed_mode: {         enable: false,         rotateX: 600,         rotateY: 600       }     },     anim: {       enable: true,       speed: 1     }   },   interactivity: {     enable: true,     mouse: {       distance: 250     },     detect_on: 'canvas', \/\/ &quot;canvas&quot; or &quot;window&quot;     mode: 'grab',     line_linked: {       opacity: .5     },     events: {       onclick: {         enable: true,         mode: 'push', \/\/ &quot;push&quot; or &quot;remove&quot; (particles)         nb: 4       }     }   },   \/* Retina Display Support *\/   retina_detect: true }); <\/code><\/pre>\n<h4><a href=\"https:\/\/www.mozilla.org\/en-US\/firefox\/developer\/\">Firefox Developer Edition<\/a><\/h4>\n<p>  <a href=\"https:\/\/www.mozilla.org\/en-US\/firefox\/developer\/\"><img decoding=\"async\" src=\"\/\/habrastorage.org\/files\/85f\/150\/8a5\/85f1508a5c41414ab3928a5f9edaf810.jpg\"\/><\/a><\/p>\n<h4>\u0417\u0430\u043f\u0430\u0434\u043d\u044b\u0435 \u043c\u044b\u0441\u043b\u0438 \u0438\u043b\u0438 \u0447\u0442\u043e \u0441\u0442\u043e\u0438\u043b\u043e \u0431\u044b \u043f\u0435\u0440\u0435\u0432\u0435\u0441\u0442\u0438 \u043d\u0430 \u0425\u0430\u0431\u0440\u0435:<\/h4>\n<p>  <\/p>\n<ul>\n<li><a href=\"https:\/\/medium.com\/@johnolilly\/happy-10th-firefox-33ddae0a5b42\">Happy 10th, Firefox<\/a><\/li>\n<li><a href=\"http:\/\/alistapart.com\/blog\/post\/overwhelmed-by-code\/\">Overwhelmed by Code<\/a><\/li>\n<li><a href=\"http:\/\/karpathy.github.io\/neuralnets\/\">Hacker&#8217;s guide to Neural Networks<\/a><\/li>\n<li><a href=\"http:\/\/www.smashingmagazine.com\/2011\/01\/19\/cleaning-up-the-mess-how-to-keep-your-coding-workflow-organized\/\">Cleaning Up The Mess: How To Keep Your Coding Workflow Organized<\/a><\/li>\n<li><a href=\"http:\/\/alistapart.com\/article\/responsive-images-in-practice\">Responsive Images in Practice<\/a><\/li>\n<li><a href=\"http:\/\/alistapart.com\/article\/the-path-to-enlightenment\">The $PATH to Enlightenment<\/a><\/li>\n<li><a href=\"https:\/\/hacks.mozilla.org\/2014\/11\/distributed-on-the-fly-image-processing-and-open-source-at-vimeo\/\">Distributed On-the-Fly Image Processing and Open Source at Vimeo<\/a><\/li>\n<li><a href=\"http:\/\/www.creativebloq.com\/javascript\/create-interactive-video-effects-111413405\">Create interactive JavaScript video effects<\/a><\/li>\n<li><a href=\"http:\/\/css-tricks.com\/gotchas-on-getting-svg-into-production\/\">5 Gotchas You\u2019re Gonna Face Getting Inline SVG Into Production<\/a><\/li>\n<li><a href=\"http:\/\/css-tricks.com\/svg-animation-on-css-transforms\/\">SVG Animation and CSS Transforms: A Complicated Love Story<\/a><\/li>\n<li><a href=\"http:\/\/www.smashingmagazine.com\/2014\/11\/03\/styling-and-animating-svgs-with-css\/\">Styling And Animating SVGs With CSS<\/a><\/li>\n<li><a href=\"http:\/\/www.sellarafaeli.com\/blog\/native_javascript_data_binding\">Native JavaScript Data-Binding<\/a><\/li>\n<li><a href=\"https:\/\/medium.com\/trek\/last-week-i-had-a-small-meltdown-on-twitter-about-npms-future-plans-around-front-end-packaging-b424dd8d367a\">JavaScript Modules: Welcome to My Emo Hellscape<\/a><\/li>\n<li><a href=\"http:\/\/tympanus.net\/codrops\/2014\/10\/30\/resizing-cropping-images-canvas\/\">Resizing and Cropping Images with Canvas<\/a><\/li>\n<li><a href=\"https:\/\/www.polymer-project.org\/articles\/spa.html\">Building single page apps using web components<\/a><\/li>\n<li><a href=\"http:\/\/tmagazine.blogs.nytimes.com\/2014\/09\/22\/design-golden-age\/?_php=true&amp;_type=blogs&amp;_r=1\">A Golden Age of Design<\/a><\/li>\n<li><a href=\"http:\/\/www.smashingmagazine.com\/2014\/11\/11\/framing-effective-messages-to-motivate-your-users\/\">Framing Effective Messages To Motivate Your Users<\/a><\/li>\n<li><a href=\"http:\/\/www.smashingmagazine.com\/2014\/11\/12\/enabling-multiscreen-tracking-with-google-analytics\/\">Enabling Multiscreen Tracking With Google Analytics<\/a><\/li>\n<li><a href=\"http:\/\/veerle.duoh.com\/design\/article\/using_linked_smartobjects_in_combination_with_layercomps_in_photoshop_cc\">Using linked SmartObjects in combination with Layercomps in Photoshop CC<\/a><\/li>\n<li><a href=\"http:\/\/alistapart.com\/blog\/post\/pixel-design\/\">That Pixel Design is so Hot Right Now<\/a><\/li>\n<li><a href=\"http:\/\/www.smashingmagazine.com\/2012\/03\/30\/publish-what-you-learn\/\">Publish What You Learn<\/a><\/li>\n<\/ul>\n<h4>\u0413\u043e\u0432\u043e\u0440\u044f\u0442 \u0438 \u043f\u043e\u043a\u0430\u0437\u044b\u0432\u0430\u044e\u0442 \u043e\u0442\u0435\u0447\u0435\u0441\u0442\u0432\u0435\u043d\u043d\u044b\u0435 \u0418\u0422 \u0440\u0435\u0441\u0443\u0440\u0441\u044b:<\/h4>\n<p>  <\/p>\n<ul>\n<li><a href=\"http:\/\/habrahabr.ru\/post\/243091\/\">\u00ab\u041b\u0438\u0446\u0435\u043d\u0437\u0438\u044f \u0434\u043b\u044f \u0432\u0430\u0448\u0435\u0433\u043e open-source \u043f\u0440\u043e\u0435\u043a\u0442\u0430\u00bb<\/a> \u043e\u0442 <a href=\"http:\/\/habrahabr.ru\/users\/marked-one\/\" class=\"user_link\">marked-one<\/a><\/li>\n<li><a href=\"http:\/\/css-live.ru\/articles\/rukovodstvo-po-svg-animaciyam-smil.html\">\u00ab\u0420\u0443\u043a\u043e\u0432\u043e\u0434\u0441\u0442\u0432\u043e \u043f\u043e SVG-\u0430\u043d\u0438\u043c\u0430\u0446\u0438\u044f\u043c (SMIL)\u00bb<\/a> \u043e\u0442 CSS Live, <a href=\"http:\/\/css-tricks.com\/guide-svg-animations-smil\/\">\u043e\u0440\u0438\u0433\u0438\u043d\u0430\u043b \u043d\u0430 CSS Tricks<\/a><\/li>\n<li><a href=\"http:\/\/habrahabr.ru\/post\/242943\/\">\u00abMeteor. \u0420\u0430\u0437\u0440\u0430\u0431\u0430\u0442\u044b\u0432\u0430\u0435\u043c TODO List\u00bb<\/a> \u043e\u0442 <a href=\"http:\/\/habrahabr.ru\/users\/movl\/\" class=\"user_link\">movl<\/a><\/li>\n<li><a href=\"http:\/\/habrahabr.ru\/post\/242191\/\">\u00ab\u0417\u0432\u043e\u043d\u0438\u043c \u043d\u0430 \u043c\u043e\u0431\u0438\u043b\u044c\u043d\u044b\u0435 \u0442\u0435\u043b\u0435\u0444\u043e\u043d\u044b \u0438\u0437 \u0431\u0440\u0430\u0443\u0437\u0435\u0440\u0430 \u0441 \u0437\u0430\u043f\u0438\u0441\u044c\u044e \u0440\u0430\u0437\u0433\u043e\u0432\u043e\u0440\u043e\u0432\u00bb<\/a> \u043e\u0442 <a href=\"http:\/\/habrahabr.ru\/users\/sterx\/\" class=\"user_link\">sterx<\/a><\/li>\n<li><a href=\"http:\/\/html5.by\/blog\/webgl-image-filters\/\">\u00abWebGl: \u0433\u0440\u0430\u0444\u0438\u0447\u0435\u0441\u043a\u0438\u0435 \u044d\u0444\u0444\u0435\u043a\u0442\u044b \u0438 \u0444\u0438\u043b\u044c\u0442\u0440\u0430\u0446\u0438\u044f \u0438\u0437\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u0439 \u043f\u043e\u0434 \u0441\u0442\u0435\u0440\u043e\u0438\u0434\u0430\u043c\u0438\u00bb<\/a> \u043e\u0442 HTML5.by.<\/li>\n<li><a href=\"http:\/\/habrahabr.ru\/post\/243247\/\">\u00ab9 \u043e\u0441\u043d\u043e\u0432\u043d\u044b\u0445 \u043f\u0440\u0438\u043d\u0446\u0438\u043f\u043e\u0432 \u043e\u0442\u0437\u044b\u0432\u0447\u0438\u0432\u043e\u0433\u043e \u0432\u0435\u0431-\u0434\u0438\u0437\u0430\u0439\u043d\u0430\u00bb<\/a> \u043e\u0442 <a href=\"http:\/\/habrahabr.ru\/users\/andrew-r\/\" class=\"user_link\">andrew-r<\/a><\/li>\n<li><a href=\"http:\/\/habrahabr.ru\/company\/wargaming\/blog\/241903\/\">\u00ab\u041f\u043e\u0434\u0431\u043e\u0440\u043a\u0430 \u0438\u043d\u0442\u0435\u0440\u0435\u0441\u043d\u044b\u0445 CSS \u0440\u0435\u0446\u0435\u043f\u0442\u043e\u0432 \u00ab\u0413\u043e\u043b\u044b\u0435 \u043f\u044f\u0442\u043d\u0438\u0446\u044b #3\u00bb\u00bb<\/a> \u043e\u0442 <a href=\"http:\/\/habrahabr.ru\/users\/paul_king\/\" class=\"user_link\">Paul_King<\/a><\/li>\n<li><a href=\"http:\/\/habrahabr.ru\/company\/2gis\/blog\/242909\/\">\u00ab\u0418\u0437\u043e\u043c\u043e\u0440\u0444\u043d\u044b\u0435 JavaScript-\u043f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u044f \u0441 Catberry.js\u00bb<\/a> \u043e\u0442 <a href=\"http:\/\/habrahabr.ru\/users\/pragmadash\/\" class=\"user_link\">pragmadash<\/a><\/li>\n<li><a href=\"http:\/\/habrahabr.ru\/post\/243097\/\">\u00abJMeter \u043a\u0430\u043a \u043e\u0442\u043d\u043e\u0441\u0438\u0442\u0435\u043b\u044c\u043d\u043e \u0443\u0434\u043e\u0431\u043d\u043e\u0435 \u0438 \u043f\u0440\u0430\u043a\u0442\u0438\u0447\u043d\u043e\u0435 \u0441\u0440\u0435\u0434\u0441\u0442\u0432\u043e \u0434\u043b\u044f \u0442\u0435\u0441\u0442\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u044f API\u00bb<\/a> \u043e\u0442 <a href=\"http:\/\/habrahabr.ru\/users\/htc-cs\/\" class=\"user_link\">htc-cs<\/a><\/li>\n<li><a href=\"http:\/\/habrahabr.ru\/post\/242161\/\">\u00ab\u0420\u0430\u0431\u043e\u0442\u0430 \u0432\u0435\u0431-\u043f\u0440\u043e\u0435\u043a\u0442\u0430 \u0432 \u0443\u0441\u043b\u043e\u0432\u0438\u044f\u0445 \u043d\u0435\u0441\u0442\u0430\u0431\u0438\u043b\u044c\u043d\u043e\u0433\u043e \u043f\u043e\u0434\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u044f\u00bb<\/a> \u043e\u0442 <a href=\"http:\/\/habrahabr.ru\/users\/zav\/\" class=\"user_link\">Zav<\/a><\/li>\n<li><a href=\"http:\/\/habrahabr.ru\/post\/242835\/\">\u00abGamepadAPI \u0438\u043b\u0438 \u0434\u0436\u043e\u0439\u0441\u0442\u0438\u043a \u0432 \u0431\u0440\u0430\u0443\u0437\u0435\u0440\u0435\u00bb<\/a> \u043e\u0442 <a href=\"http:\/\/habrahabr.ru\/users\/louter\/\" class=\"user_link\">Louter<\/a><\/li>\n<li><a href=\"http:\/\/habrahabr.ru\/company\/mailru\/blog\/243147\/\">\u00ab\u041f\u0440\u0438\u0433\u043b\u0430\u0448\u0430\u0435\u043c \u043d\u0430 \u043a\u043e\u043d\u0444\u0435\u0440\u0435\u043d\u0446\u0438\u044e \u043f\u043e web-\u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u043a\u0435 29 \u043d\u043e\u044f\u0431\u0440\u044f\u00bb<\/a> \u043e\u0442 <a href=\"http:\/\/habrahabr.ru\/users\/teammrg\/\" class=\"user_link\">TeamMRG<\/a><\/li>\n<\/ul>\n<h4>\u041d\u0430\u043f\u043e\u0441\u043b\u0435\u0434\u043e\u043a:<\/h4>\n<p>  <\/p>\n<ul>\n<li><a href=\"http:\/\/www.screeps.com\/\">Screeps<\/a> \u2014 \u043f\u0435\u0440\u0432\u0430\u044f \u0441\u0442\u0440\u0430\u0442\u0435\u0433\u0438\u0447\u0435\u0441\u043a\u043e\u0439 MMO-\u0438\u0433\u0440\u0430 \u0434\u043b\u044f \u043f\u0440\u043e\u0433\u0440\u0430\u043c\u043c\u0438\u0441\u0442\u043e\u0432.<br \/>  <iframe loading=\"lazy\" width=\"560\" height=\"349\" src=\"\/\/www.youtube.com\/embed\/pAfPqxzyBIc?wmode=opaque\" frameborder=\"0\" allowfullscreen><\/iframe>   <\/li>\n<li><a href=\"https:\/\/github.com\/twitter\/twemoji\">Twemoji<\/a> \u2014 \u043a\u043e\u043b\u043b\u0435\u043a\u0446\u0438\u044f Unicode Emoji \u0441\u043c\u0430\u0439\u043b\u0438\u043a\u043e\u0432 \u043e\u0442 Twitter.<\/li>\n<li><a href=\"https:\/\/github.com\/kripken\/sql.js\">SQL.js<\/a> \u2014 SQLite \u0442\u0435\u043f\u0435\u0440\u044c \u0434\u043e\u0441\u0442\u0443\u043f\u0435\u043d \u0432 JavaScript.<\/li>\n<li><a href=\"https:\/\/github.com\/sosedoff\/pgweb\/\">PGweb.js<\/a> \u2014 PostgreSQL \u0432 \u0431\u0440\u0430\u0443\u0437\u0435\u0440\u0435.<\/li>\n<li><a href=\"https:\/\/github.com\/techfort\/LokiJS\">Loki.js<\/a> \u2014 embeddable \/ in-memory database.<\/li>\n<li><a href=\"https:\/\/github.com\/keen\/dashboards\">Dashboards<\/a> \u2014 \u043e\u0442\u0437\u044b\u0432\u0447\u0438\u0432\u044b\u0435 \u0448\u0430\u0431\u043b\u043e\u043d\u044b \u00ab\u043f\u0440\u0438\u0431\u043e\u0440\u043d\u044b\u0445 \u043f\u0430\u043d\u0435\u043b\u0435\u0439\u00bb \u043d\u0430 Bootstrap.<\/li>\n<li><a href=\"https:\/\/github.com\/naholyr\/github-todos\">Github Todos<\/a> \u2014 \u043a\u043e\u043d\u0432\u0435\u0440\u0442\u0438\u0440\u0443\u0435\u0442 \u0432\u0430\u0448 ToDo \u0441\u043f\u0438\u0441\u043e\u043a \u0432 GitHub Issues<\/li>\n<li><a href=\"https:\/\/github.com\/maximecb\/Higgs\">Higgs<\/a> \u2014 JavaScript Virtual Machine.<\/li>\n<li><a href=\"https:\/\/github.com\/robotlolita\/raven\">Raven<\/a> \u2014 \u0442\u0435\u043a\u0441\u0442\u043e\u0432\u044b\u0439 \u0440\u0435\u0434\u0430\u043a\u0442\u043e\u0440 \u0441 \u0430\u043a\u0446\u0435\u043d\u0442\u043e\u043c \u043d\u0430 \u0442\u0438\u043f\u043e\u0433\u0440\u0430\u0444\u0438\u043a\u0443.<\/li>\n<li><a href=\"https:\/\/github.com\/Mathachew\/jquery-autotab\">jQuery Autotab<\/a> \u2014 \u043d\u0430\u0441\u0442\u0440\u0430\u0438\u0432\u0430\u0435\u043c \u0442\u0430\u0431\u0443\u043b\u044f\u0446\u0438\u044e \u0434\u043b\u044f \u0444\u043e\u0440\u043c.<\/li>\n<li><a href=\"https:\/\/github.com\/KrauseFx\/deliver\">Deliver<\/a> \u2014 \u043f\u0440\u043e\u0441\u0442\u043e\u0439 \u0434\u0435\u043f\u043b\u043e\u0439 \u0441\u043a\u0440\u0438\u043d\u0448\u043e\u0442\u043e\u0432, \u0434\u0430\u0442\u044b \u043f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u0439 \u0438 \u043e\u0431\u043d\u043e\u0432\u043b\u0435\u043d\u0438\u0439 \u0432 App Store \u043d\u0430 Ruby.<\/li>\n<li><a href=\"https:\/\/github.com\/derekparker\/delve\">Delve<\/a> \u2014 \u0434\u0435\u0431\u0430\u0433\u0433\u0435\u0440 \u0434\u043b\u044f Go.<\/li>\n<li><a href=\"https:\/\/github.com\/deis\/deis\">Deis<\/a> \u2014 Your PaaS. Your Rules.<\/li>\n<li><a href=\"https:\/\/github.com\/cockroachdb\/cockroach\">Cockroachdb<\/a> \u2014 Scalable, Geo-Replicated, Transactional Datastore \u0434\u043b\u044f Go.<\/li>\n<li><a href=\"https:\/\/github.com\/balloob\/home-assistant\">Home Assistant<\/a> \u2014 \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0430 \u0434\u043b\u044f \u043f\u0440\u043e\u0433\u0440\u0430\u043c\u043c\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u044f \u0443\u043c\u043d\u043e\u0433\u043e \u0434\u043e\u043c\u0430 \u043d\u0430 Python.<\/li>\n<li><a href=\"https:\/\/github.com\/google\/nogotofail\">Nogotofail<\/a> \u2014 network security testing tool.<\/li>\n<li><a href=\"http:\/\/blogs.skype.com\/2014\/11\/14\/please-welcome-skype-for-web-beta\/\">Skype \u0442\u0435\u043f\u0435\u0440\u044c \u0434\u043e\u0441\u0442\u0443\u043f\u0435\u043d \u0432 \u0431\u0440\u0430\u0443\u0437\u0435\u0440\u0435<\/a><\/li>\n<\/ul>\n<p>  &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;<a href=\"http:\/\/habrahabr.ru\/post\/241539\/\"><b>\u041f\u0440\u0435\u0434\u044b\u0434\u0443\u0449\u0430\u044f \u043f\u043e\u0434\u0431\u043e\u0440\u043a\u0430 (\u0412\u044b\u043f\u0443\u0441\u043a 32)<\/b><\/a><\/p>\n<p>  \u041f\u0440\u0438\u043d\u043e\u0448\u0443 \u0438\u0437\u0432\u0438\u043d\u0435\u043d\u0438\u044f \u0437\u0430 \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u044b\u0435 \u043e\u043f\u0435\u0447\u0430\u0442\u043a\u0438. \u0415\u0441\u043b\u0438 \u0432\u044b \u0437\u0430\u043c\u0435\u0442\u0438\u043b\u0438 \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u0443 \u2014 \u043d\u0430\u043f\u0438\u0448\u0438\u0442\u0435, \u043f\u043e\u0436\u0430\u043b\u0443\u0439\u0441\u0442\u0430, \u0432 \u043b\u0438\u0447\u043a\u0443.<\/p>\n<p>  \u0421\u043f\u0430\u0441\u0438\u0431\u043e \u0432\u0441\u0435\u043c \u0437\u0430 \u0432\u043d\u0438\u043c\u0430\u043d\u0438\u0435.<\/p>\n<div class=\"polling\">\n<form action=\"\/json\/polling\/\" class=\"poll\" method=\"post\">\n<div class=\"poll_title\">\u041f\u043e\u043d\u0440\u0430\u0432\u0438\u043b\u0430\u0441\u044c \u043b\u0438 \u0412\u0430\u043c \u043f\u043e\u0434\u0431\u043e\u0440\u043a\u0430?<\/div>\n<p>  \t\t<input type=\"hidden\" name=\"post_id\" value=\"243343\"\/> \t\t<input type=\"hidden\" name=\"polling_question_id\" value=\"12765\"\/>  \t\t<\/p>\n<table class=\"answer\">\n<tr>\n<td class=\"input\"> \t\t\t\t\t<input type=\"radio\" id=\"vv63287\" \t\t\t\t\t\tclass=\"radio js-field-data\" \t\t\t\t\t\tname=\"variant[]\" \t\t\t\t\t\tvalue=\"63287\" \/> \t\t\t\t<\/td>\n<td class=\"label\"> \t\t\t\t\t<label for=\"vv63287\">\u0414\u0430<\/label> \t\t\t\t<\/td>\n<\/tr>\n<tr>\n<td class=\"input\"> \t\t\t\t\t<input type=\"radio\" id=\"vv63289\" \t\t\t\t\t\tclass=\"radio js-field-data\" \t\t\t\t\t\tname=\"variant[]\" \t\t\t\t\t\tvalue=\"63289\" \/> \t\t\t\t<\/td>\n<td class=\"label\"> \t\t\t\t\t<label for=\"vv63289\">\u041d\u0435\u0442<\/label> \t\t\t\t<\/td>\n<\/tr>\n<\/table>\n<p class=\"for_users_only_msg\">\u0422\u043e\u043b\u044c\u043a\u043e \u0437\u0430\u0440\u0435\u0433\u0438\u0441\u0442\u0440\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u044b\u0435 \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u0438 \u043c\u043e\u0433\u0443\u0442 \u0443\u0447\u0430\u0441\u0442\u0432\u043e\u0432\u0430\u0442\u044c \u0432 \u043e\u043f\u0440\u043e\u0441\u0435. <a href=\"https:\/\/habrahabr.ru\/auth\/login\/\">\u0412\u043e\u0439\u0434\u0438\u0442\u0435<\/a>, \u043f\u043e\u0436\u0430\u043b\u0443\u0439\u0441\u0442\u0430.<\/p>\n<p class=\"total\">\u041f\u0440\u043e\u0433\u043e\u043b\u043e\u0441\u043e\u0432\u0430\u043b\u043e 34 \u0447\u0435\u043b\u043e\u0432\u0435\u043a\u0430. \u0412\u043e\u0437\u0434\u0435\u0440\u0436\u0430\u043b\u043e\u0441\u044c 4 \u0447\u0435\u043b\u043e\u0432\u0435\u043a\u0430.<\/p>\n<\/p><\/form>\n<\/p><\/div>\n<div class=\"clear\"><\/div>\n<\/p><\/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\/243343\/\"> http:\/\/habrahabr.ru\/post\/243343\/<\/a><\/p>\n","protected":false},"excerpt":{"rendered":"<div class=\"content html_format\">     \t\u0414\u043e\u0431\u0440\u043e\u0433\u043e \u0432\u0440\u0435\u043c\u0435\u043d\u0438 \u0441\u0443\u0442\u043e\u043a, \u0443\u0432\u0430\u0436\u0430\u0435\u043c\u044b\u0435 \u0445\u0430\u0431\u0440\u0430\u0432\u0447\u0430\u043d\u0435. \u0417\u0430 \u043f\u043e\u0441\u043b\u0435\u0434\u043d\u0435\u0435 \u0432\u0440\u0435\u043c\u044f \u044f \u0443\u0432\u0438\u0434\u0435\u043b \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u0438\u043d\u0442\u0435\u0440\u0435\u0441\u043d\u044b\u0445 \u0438 \u043f\u043e\u043b\u0435\u0437\u043d\u044b\u0445 \u0438\u043d\u0441\u0442\u0440\u0443\u043c\u0435\u043d\u0442\u043e\u0432\/\u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\/\u0441\u043e\u0431\u044b\u0442\u0438\u0439, \u043a\u043e\u0442\u043e\u0440\u044b\u043c\u0438 \u0445\u043e\u0447\u0443 \u043f\u043e\u0434\u0435\u043b\u0438\u0442\u044c\u0441\u044f \u0441 \u0425\u0430\u0431\u0440\u043e\u043c. <\/p>\n<h4><a href=\"https:\/\/github.com\/ConnorAtherton\/walkway\">Walkway.js<\/a> \u0438 <a href=\"https:\/\/github.com\/maxwellito\/vivus\">Vivus.js<\/a><\/h4>\n<p>  <img decoding=\"async\" src=\"\/\/habrastorage.org\/files\/881\/211\/b22\/881211b225a44bfeab32d862d97a7551.jpg\"\/><br \/>  \u0412\u044b \u0432\u0438\u0434\u0435\u043b\u0438 <a href=\"http:\/\/www.polygon.com\/a\/ps4-review\/video_review\">\u044d\u0442\u043e\u0442 \u0432\u0435\u043b\u0438\u043a\u043e\u043b\u0435\u043f\u043d\u044b\u0439 \u043b\u044d\u043d\u0434\u0438\u043d\u0433<\/a> \u043f\u043e\u0441\u0432\u044f\u0449\u0435\u043d\u043d\u044b\u0439 \u0430\u043d\u043e\u043d\u0441\u0443 Sony PlayStation 4? \u041e\u0431\u0440\u0430\u0442\u0438\u0442\u0435 \u0432\u043d\u0438\u043c\u0430\u043d\u0438\u0435 \u043d\u0430 \u0430\u043d\u0438\u043c\u0430\u0446\u0438\u044e SVG \u043e\u0431\u044a\u0435\u043a\u0442\u043e\u0432 \u0441\u043e\u0441\u0442\u043e\u044f\u0449\u0438\u0445 \u0438\u0437 \u043a\u043e\u043d\u0442\u0443\u0440\u043e\u0432. \u041e\u043d\u0438 \u0441\u043b\u043e\u0432\u043d\u043e \u0440\u0438\u0441\u0443\u044e\u0442\u0441\u044f \u0445\u0443\u0434\u043e\u0436\u043d\u0438\u043a\u043e\u043c \u0432 \u0440\u0435\u0436\u0438\u043c\u0435 \u0440\u0435\u0430\u043b\u044c\u043d\u043e\u0433\u043e \u0432\u0440\u0435\u043c\u0435\u043d\u0438. \u041e\u0442\u043d\u044b\u043d\u0435 \u044d\u0442\u043e\u0442 \u044d\u0444\u0444\u0435\u043a\u0442 \u043c\u043e\u0436\u043d\u043e \u043b\u0435\u0433\u043a\u043e \u043f\u043e\u0432\u0442\u043e\u0440\u0438\u0442\u044c \u0441 \u043f\u043e\u043c\u043e\u0449\u044c\u044e Walkway \u0438 Vivus. \u041e\u0431\u0435 \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0438 \u043c\u0430\u043a\u0441\u0438\u043c\u0430\u043b\u044c\u043d\u043e \u043f\u0440\u043e\u0441\u0442\u044b \u0432 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u0438 \u0438 \u043f\u0440\u0438\u043c\u0435\u043d\u0438\u043c\u044b \u0442\u043e\u043b\u044c\u043a\u043e \u0434\u043b\u044f <b>path<\/b> \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u043e\u0432, \u043f\u043e\u0441\u043a\u043e\u043b\u044c\u043a\u0443 \u043f\u0440\u0438\u043d\u0446\u0438\u043f \u0438\u0445 \u0440\u0430\u0431\u043e\u0442\u044b \u043e\u0441\u043d\u043e\u0432\u044b\u0432\u0430\u0435\u0442\u0441\u044f \u043d\u0430 \u0432\u0437\u0430\u0438\u043c\u043e\u0434\u0435\u0439\u0441\u0442\u0432\u0438\u0438 \u0441 CSS \u0441\u0432\u043e\u0439\u0441\u0442\u0432\u043e\u043c <b>strokeDashoffset<\/b>. \u0425\u043e\u0442\u044c \u0438 \u0443 Walkway \u0437\u043d\u0430\u0447\u0438\u0442\u0435\u043b\u044c\u043d\u043e \u0431\u043e\u043b\u044c\u0448\u0435 \u0437\u0432\u0435\u0437\u0434 \u043d\u0430 \u0413\u0438\u0442\u0445\u0430\u0431\u0435, \u0437\u0430\u0442\u043e Vivus \u043f\u0440\u0435\u0434\u043e\u0441\u0442\u0430\u0432\u043b\u044f\u0435\u0442 \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u0432\u0430\u0440\u0438\u0430\u043d\u0442\u043e\u0432 \u043e\u0442\u0440\u0438\u0441\u043e\u0432\u043a\u0438: Delayed, Async \u0438 OneByOne.<\/p>\n<pre><code class=\"javascript\">\/\/Walkway var svg = new Walkway('#test');  svg.draw(function() {   console.log('Animation finished'); });  \/\/Vivus new Vivus('my-svg-id', {type: 'delayed', duration: 200}, myCallback); <\/code><\/pre>\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-243343","post","type-post","status-publish","format-standard","hentry"],"_links":{"self":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/243343","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=243343"}],"version-history":[{"count":0,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/243343\/revisions"}],"wp:attachment":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=243343"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=243343"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=243343"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}