{"id":280326,"date":"2016-11-02T09:35:04","date_gmt":"2016-11-02T06:35:04","guid":{"rendered":"http:\/\/savepearlharbor.com\/?p=280326"},"modified":"-0001-11-30T00:00:00","modified_gmt":"-0001-11-29T21:00:00","slug":"","status":"publish","type":"post","link":"https:\/\/savepearlharbor.com\/?p=280326","title":{"rendered":"\u041f\u0430\u0442\u0442\u0435\u0440\u043d \u0421\u0442\u0440\u0430\u0442\u0435\u0433\u0438\u044f \u043d\u0430 JavaScript"},"content":{"rendered":"<p>\u0420\u0430\u043d\u0435\u0435 \u044f \u0443\u0436\u0435 \u043f\u0443\u0431\u043b\u0438\u043a\u043e\u0432\u0430\u043b <a href=\"https:\/\/habrahabr.ru\/post\/191480\/\">\u043f\u0435\u0440\u0435\u0432\u043e\u0434<\/a> \u0441\u0442\u0430\u0442\u044c\u0438 \u0441 \u0442\u0430\u043a\u0438\u043c \u0436\u0435 \u043d\u0430\u0437\u0432\u0430\u043d\u0438\u0435\u043c. \u0418 \u043f\u043e\u0434 \u043d\u0435\u0439 \u0442\u043e\u0432\u0430\u0440\u0438\u0449 <a href=\"https:\/\/habrahabr.ru\/users\/atei\/\" class=\"user_link\">aTei<\/a> \u043e\u0441\u0442\u0430\u0432\u0438\u043b <a href=\"https:\/\/habrahabr.ru\/post\/191480\/#comment_6702426\">\u043a\u043e\u043c\u043c\u0435\u043d\u0442\u0430\u0440\u0438\u0439<\/a>:<\/p>\n<p>  <\/p>\n<blockquote><p>\u041f\u043e-\u043c\u043e\u0435\u043c\u0443 \u043a\u043e\u0435-\u0447\u0435\u0433\u043e \u043d\u0435 \u0445\u0432\u0430\u0442\u0430\u0435\u0442 \u0432 \u044d\u0442\u043e\u0439 \u0441\u0442\u0430\u0442\u044c\u0435 \u0438 \u0432 \u0441\u0442\u0430\u0442\u044c\u0435 \u0432 \u0432\u0438\u043a\u0438\u043f\u0435\u0434\u0438\u0435 \u2014 \u043f\u0440\u0438\u043c\u0435\u0440\u0430 \u0432 \u0441\u0442\u0438\u043b\u0435 \u00ab\u0411\u044b\u043b\u043e \u043f\u043b\u043e\u0445\u043e \u2014 \u0441\u0442\u0430\u043b\u043e \u0445\u043e\u0440\u043e\u0448\u043e\u00bb. \u0421\u0440\u0430\u0437\u0443 \u043f\u043e\u043b\u0443\u0447\u0430\u0435\u0442\u0441\u044f \u00ab\u0445\u043e\u0440\u043e\u0448\u043e\u00bb \u0438 \u043d\u0435 \u0434\u043e\u0441\u0442\u0430\u0442\u043e\u0447\u043d\u043e \u044f\u0441\u043d\u043e, \u0447\u0442\u043e \u044d\u0442\u043e \u0434\u0435\u0439\u0441\u0442\u0432\u0438\u0442\u0435\u043b\u044c\u043d\u043e \u0445\u043e\u0440\u043e\u0448\u043e. \u0411\u0443\u0434\u0443 \u0431\u043b\u0430\u0433\u043e\u0434\u0430\u0440\u0435\u043d \u0437\u0430 \u0442\u0430\u043a\u043e\u0439 \u043f\u0440\u0438\u043c\u0435\u0440.<\/p><\/blockquote>\n<p>\u041e\u0442\u0432\u0435\u0442\u0430 \u043d\u0430 \u043d\u0435\u0433\u043e \u0442\u0430\u043a \u043d\u0438\u043a\u0442\u043e \u0438 \u043d\u0435 \u0434\u0430\u043b \u0434\u043e \u0441\u0438\u0445 \u043f\u043e\u0440. \u0417\u0430 3 \u0433\u043e\u0434\u0430 \u044f \u043d\u0430\u0431\u0440\u0430\u043b\u0441\u044f <del>\u043e\u043f\u044b\u0442\u0430<\/del> \u0441\u043c\u0435\u043b\u043e\u0441\u0442\u0438 \u0438 \u0442\u0435\u043f\u0435\u0440\u044c, \u043a\u0430\u043a \u043e\u0442\u0432\u0435\u0442 \u043d\u0430 \u044d\u0442\u043e\u0442 \u043a\u043e\u043c\u043c\u0435\u043d\u0442\u0430\u0440\u0438\u0439, \u0445\u043e\u0447\u0443 \u043d\u0430\u043f\u0438\u0441\u0430\u0442\u044c \u043e \u043f\u0430\u0442\u0442\u0435\u0440\u043d\u0435 \u0421\u0442\u0440\u0430\u0442\u0435\u0433\u0438\u044f \u043e\u0442 \u0441\u0432\u043e\u0435\u0433\u043e \u0438\u043c\u0435\u043d\u0438.<\/p>\n<p>  <\/p>\n<p>\u041a\u0440\u043e\u0445\u0438 \u0442\u0435\u043e\u0440\u0438\u0438 \u0432\u0441\u0442\u0440\u0435\u0447\u0430\u044e\u0442\u0441\u044f \u0433\u0434\u0435-\u0442\u043e \u043f\u043e \u0442\u0435\u043a\u0441\u0442\u0443. \u041d\u043e \u0431\u043e\u043b\u044c\u0448\u0430\u044f \u0447\u0430\u0441\u0442\u044c \u0441\u0442\u0430\u0442\u044c\u0438 \u043f\u043e\u0441\u0432\u044f\u0449\u0435\u043d\u0430 \u043f\u0440\u0430\u043a\u0442\u0438\u0447\u0435\u0441\u043a\u0438\u043c \u0441\u043f\u043e\u0441\u043e\u0431\u0430\u043c \u043f\u0440\u0438\u043c\u0435\u043d\u0435\u043d\u0438\u044f \u044d\u0442\u043e\u0433\u043e \u043f\u0430\u0442\u0442\u0435\u0440\u043d\u0430 \u0438 \u0432\u0430\u0440\u0438\u0430\u043d\u0442\u0430\u043c \u0435\u0433\u043e \u043f\u0440\u0438\u043c\u0435\u043d\u0435\u043d\u0438\u044f \u0438\u0437\u0431\u0435\u0436\u0430\u0442\u044c.<\/p>\n<p><a name=\"habracut\"><\/a>  <\/p>\n<p>\u0414\u0430\u043d\u043e: \u043d\u0430\u043f\u0438\u0441\u0430\u0442\u044c \u041b\u043e\u0433\u0433\u0435\u0440, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u043f\u043e\u0437\u0432\u043e\u043b\u044f\u0435\u0442:<\/p>\n<p>  <\/p>\n<ul>\n<li>\u041f\u0438\u0441\u0430\u0442\u044c \u043b\u043e\u0433\u0438 3\u0445 \u0443\u0440\u043e\u0432\u043d\u0435\u0439: <code>log<\/code>, <code>warn<\/code> \u0438 <code>error<\/code><\/li>\n<li>\u0412\u044b\u0431\u0438\u0440\u0430\u0442\u044c destination (\u043c\u0435\u0441\u0442\u043e \u043d\u0430\u0437\u043d\u0430\u0447\u0435\u043d\u0438\u044f) \u0434\u043b\u044f \u043b\u043e\u0433\u043e\u0432: console, \u0441\u0442\u0440\u0430\u043d\u0438\u0446\u0430 (\u0432\u044b\u0431\u0440\u0430\u043d\u044b \u0434\u043b\u044f \u043d\u0430\u0433\u043b\u044f\u0434\u043d\u043e\u0441\u0442\u0438)<br \/> \n<ul>\n<li>\u0415\u0434\u0438\u043d\u043e\u0436\u0434\u044b<\/li>\n<li>\u041c\u043d\u043e\u0436\u0435\u0441\u0442\u0432\u043e \u0440\u0430\u0437<\/li>\n<\/ul>\n<\/li>\n<li>\u0414\u043e\u0431\u0430\u0432\u043b\u044f\u0442\u044c \u043d\u043e\u0432\u044b\u0435 destination \u043d\u0435 \u0432\u043d\u043e\u0441\u044f \u0438\u0437\u043c\u0435\u043d\u0435\u043d\u0438\u0439 \u0432 \u043a\u043e\u0434 \u041b\u043e\u0433\u0433\u0435\u0440\u0430. \u041d\u0430\u043f\u0440\u0438\u043c\u0435\u0440 file, ftp, mysql, mongo, etc.<\/li>\n<li>\u0414\u043e\u0431\u0430\u0432\u043b\u044f\u0442\u044c \u043d\u043e\u043c\u0435\u0440 (\u043a\u043e\u043b-\u0432\u043e \u0432\u044b\u0437\u043e\u0432\u043e\u0432) \u0432 \u0437\u0430\u043f\u0438\u0441\u044c \u043b\u043e\u0433\u0430<\/li>\n<li>\u0418\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u043d\u0435\u0437\u0430\u0432\u0438\u0441\u0438\u043c\u044b\u0445 \u041b\u043e\u0433\u0433\u0435\u0440\u043e\u0432<\/li>\n<\/ul>\n<p>  <\/p>\n<p>\u0412\u0442\u043e\u0440\u043e\u0439 \u043f\u0443\u043d\u043a\u0442 \u043f\u0440\u0435\u0434\u043f\u043e\u043b\u0430\u0433\u0430\u0435\u0442 \u0435\u0434\u0438\u043d\u044b\u0439 &quot;\u0438\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441&quot;, \u0447\u0442\u043e \u0431\u044b \u043d\u0435 \u043f\u0440\u0438\u0448\u043b\u043e\u0441\u044c \u0440\u0430\u0434\u0438 \u0441\u043c\u0435\u043d\u044b destination \u043f\u0435\u0440\u0435\u043f\u0438\u0441\u044b\u0432\u0430\u0442\u044c \u0432\u0441\u0435 \u0441\u0442\u0440\u043e\u043a\u0438 \u0433\u0434\u0435 \u0432\u0441\u0442\u0440\u0435\u0447\u0430\u0435\u0442\u0441\u044f \u0432\u044b\u0437\u043e\u0432 \u041b\u043e\u0433\u0433\u0435\u0440\u0430.<\/p>\n<p>  <\/p>\n<hr\/>\n<p>  <\/p>\n<h1 id=\"alternativy\">\u0410\u043b\u044c\u0442\u0435\u0440\u043d\u0430\u0442\u0438\u0432\u044b<\/h1>\n<p>  <\/p>\n<p>\u0421\u043f\u0435\u0440\u0432\u0430 \u043f\u0440\u0438\u0432\u0435\u0434\u0443 \u0434\u0432\u0430 \u0432\u0430\u0440\u0438\u0430\u043d\u0442\u0430 &quot;\u0440\u0435\u0448\u0435\u043d\u0438\u044f&quot; \u0443\u043c\u044b\u0448\u043b\u0435\u043d\u043d\u043e \u0438\u0437\u0431\u0435\u0433\u0430\u044e\u0449\u0438\u0445 \u043f\u0440\u0438\u0437\u043d\u0430\u043a\u043e\u0432 \u0421\u0442\u0440\u0430\u0442\u0435\u0433\u0438\u0438.<\/p>\n<p>  <\/p>\n<h2 id=\"funkcionalnyy-podhod\">\u0424\u0443\u043d\u043a\u0446\u0438\u043e\u043d\u0430\u043b\u044c\u043d\u044b\u0439 \u043f\u043e\u0434\u0445\u043e\u0434<\/h2>\n<p>  <\/p>\n<p>\u041f\u043e\u043f\u0440\u043e\u0431\u0443\u0435\u043c \u0441\u0434\u0435\u043b\u0430\u0442\u044c \u044d\u0442\u043e <abbr title=\"\u044f\u0432\u043b\u044f\u044e\u0442\u0441\u044f \u0434\u0435\u0442\u0435\u0440\u043c\u0438\u043d\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u044b\u043c\u0438 \u0438 \u043d\u0435 \u043e\u0431\u043b\u0430\u0434\u0430\u044e\u0442 \u043f\u043e\u0431\u043e\u0447\u043d\u044b\u043c\u0438 \u044d\u0444\u0444\u0435\u043a\u0442\u0430\u043c\u0438\">\u0447\u0438\u0441\u0442\u044b\u043c\u0438 \u0444\u0443\u043d\u043a\u0446\u0438\u044f\u043c\u0438<\/abbr>:<\/p>\n<p>  <\/p>\n<p>\u0412\u043e-\u043f\u0435\u0440\u0432\u044b\u0445, \u043d\u0430\u043c \u043f\u043e\u043d\u0430\u0434\u043e\u0431\u044f\u0442\u0441\u044f \u0434\u0432\u0435 \u0444\u0443\u043d\u043a\u0446\u0438\u0438 \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u0431\u0443\u0434\u0443\u0442 \u0432\u044b\u043f\u043e\u043b\u043d\u044f\u0442\u044c \u043e\u0441\u043d\u043e\u0432\u043d\u0443\u044e \u0440\u0430\u0431\u043e\u0442\u0443:<\/p>\n<p>  <\/p>\n<pre><code>const logToConsole = (lvl,count,msg) =&gt; console[lvl](`${count++}: ${msg}`) || count;  const logToDOM = (lvl,count,msg,node) =&gt;     (node.innerHTML += `&lt;div class=&quot;${lvl}&quot;&gt;${count++}: ${msg}&lt;\/div&gt;`) &amp;&amp; count;<\/code><\/pre>\n<p>  <\/p>\n<p>\u041e\u0431\u0435 \u043e\u043d\u0438 \u0432\u044b\u043f\u043e\u043b\u043d\u044f\u044e\u0442 \u0441\u0432\u043e\u044e \u043e\u0441\u043d\u043e\u0432\u043d\u0443\u044e \u0444\u0443\u043d\u043a\u0446\u0438\u044e, \u0430 \u0437\u0430\u0442\u0435\u043c \u0432\u043e\u0437\u0432\u0440\u0430\u0449\u0430\u044e\u0442 \u043d\u043e\u0432\u043e\u0435 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435 <code>count<\/code>.<\/p>\n<p>  <\/p>\n<p>\u0412\u043e-\u0432\u0442\u043e\u0440\u044b\u0445, \u043d\u0443\u0436\u0435\u043d \u043a\u0430\u043a\u043e\u0439-\u0442\u043e \u0435\u0434\u0438\u043d\u044b\u0439 \u0438\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441 \u0438\u0445 \u043e\u0431\u044a\u0435\u0434\u0438\u043d\u044f\u044e\u0449\u0438\u0439. \u0418 \u043d\u0430 \u044d\u0442\u043e\u043c \u043c\u044b \u0432\u0441\u0442\u0440\u0435\u0447\u0430\u0435\u043c \u043f\u0435\u0440\u0432\u0443\u044e \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u0443\u2026 \u0422\u0430\u043a \u043a\u0430\u043a \u0447\u0438\u0441\u0442\u044b\u0435 \u0444\u0443\u043d\u043a\u0446\u0438\u0438 \u043d\u0435 \u0445\u0440\u0430\u043d\u044f\u0442 \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u0439, \u043d\u0435 \u043c\u043e\u0433\u0443\u0442 \u0432\u043b\u0438\u044f\u0442\u044c \u043d\u0430 \u0432\u043d\u0435\u0448\u043d\u0438\u0435 \u043f\u0435\u0440\u0435\u043c\u0435\u043d\u043d\u044b\u0435 \u0438 \u043d\u0435 \u0438\u043c\u0435\u044e\u0442 \u043f\u0440\u043e\u0447\u0438\u0445 \u0441\u0430\u0439\u0434-\u044d\u0444\u0444\u0435\u043a\u0442\u043e\u0432 \u2014 \u0443 \u043d\u0430\u0441 \u043f\u0440\u0430\u043a\u0442\u0438\u0447\u0435\u0441\u043a\u0438 \u043d\u0435 \u043e\u0441\u0442\u0430\u0451\u0442\u0441\u044f \u0434\u0440\u0443\u0433\u0438\u0445 \u0432\u0430\u0440\u0438\u0430\u043d\u0442\u043e\u0432, \u043a\u0440\u043e\u043c\u0435 \u043a\u0430\u043a \u0437\u0430\u0445\u0430\u0440\u0434\u043a\u043e\u0434\u0438\u0442\u044c \u0432\u044b\u0431\u043e\u0440 destination \u0432\u043d\u0443\u0442\u0440\u0438 \u043e\u0441\u043d\u043e\u0432\u043d\u043e\u0439 \u0444\u0443\u043d\u043a\u0446\u0438\u0438. \u041d\u0430\u043f\u0440\u0438\u043c\u0435\u0440 \u0442\u0430\u043a:<\/p>\n<p>  <\/p>\n<pre><code>const Logger = (options) =&gt; {     switch(options.destination){         case 'console': return logToConsole;         case 'dom': return (...args) =&gt; logToDOM.apply(null,[...args,options.node]);         default: throw new Error(`type '${type}' is not availible`);     }; };<\/code><\/pre>\n<p>  <\/p>\n<p>\u0422\u0435\u043f\u0435\u0440\u044c, \u043e\u0431\u044a\u044f\u0432\u0438\u0432 \u0432 \u043a\u043b\u0438\u0435\u043d\u0442\u0441\u043a\u043e\u043c \u043a\u043e\u0434\u0435 \u0432\u0441\u0435 \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u044b\u0435 \u043f\u0435\u0440\u0435\u043c\u0435\u043d\u043d\u044b\u0435, \u043c\u044b \u043c\u043e\u0436\u0435\u043c \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u043d\u0430\u0448 \u041b\u043e\u0433\u0433\u0435\u0440:<\/p>\n<p>  <\/p>\n<pre><code>let logCount = 0; const log2console = {destination: 'console'}; const log2dom = {     destination: 'dom'    ,node: document.querySelector('#log') };  let logdestination = log2console; logCount = Logger(logdestination)('log',logCount,'this goes to console'); logdestination = log2dom; logCount = Logger(logdestination)('log',logCount,'this goes to dom');<\/code><\/pre>\n<p>  <\/p>\n<p>\u0414\u0443\u043c\u0430\u044e \u043d\u0435\u0434\u043e\u0441\u0442\u0430\u0442\u043a\u0438 \u0442\u0430\u043a\u043e\u0433\u043e \u043f\u043e\u0434\u0445\u043e\u0434\u0430 \u043e\u0447\u0435\u0432\u0438\u0434\u043d\u044b. \u041d\u043e \u0441\u0430\u043c\u044b\u0439 \u0433\u043b\u0430\u0432\u043d\u044b\u0439 \u2014 \u043e\u043d \u043d\u0435 \u0443\u0434\u043e\u0432\u043b\u0435\u0442\u0432\u043e\u0440\u044f\u0435\u0442 \u0442\u0440\u0435\u0442\u044c\u0435\u043c\u0443 \u0443\u0441\u043b\u043e\u0432\u0438\u044e: <em>\u0414\u043e\u0431\u0430\u0432\u043b\u044f\u0442\u044c \u043d\u043e\u0432\u044b\u0435 destination \u043d\u0435 \u0432\u043d\u043e\u0441\u044f \u0438\u0437\u043c\u0435\u043d\u0435\u043d\u0438\u0439 \u0432 \u043a\u043e\u0434 \u041b\u043e\u0433\u0433\u0435\u0440\u0430.<\/em> \u0412\u0435\u0434\u044c \u0434\u043e\u0431\u0430\u0432\u0438\u0432 \u043d\u043e\u0432\u044b\u0439 destination \u043c\u044b \u0434\u043e\u043b\u0436\u043d\u044b \u0432\u043d\u0435\u0441\u0442\u0438 \u0435\u0433\u043e \u0432 <code>switch(options.destination)<\/code>.<\/p>\n<p>  <\/p>\n<p>\u0420\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442. <em>\u0412\u043a\u043b\u044e\u0447\u0438\u0442\u0435 DevTools console \u043f\u0435\u0440\u0435\u0434 \u043f\u0435\u0440\u0435\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u0435\u043c \u043d\u0430 \u0432\u043a\u043b\u0430\u0434\u043a\u0443 Result<\/em><\/p>\n<p>  <\/p>\n<div class=\"oembed\">\n<div>\n<div style=\"left: 0px; width: 100%; height: 0px; position: relative; padding-bottom: 56.25%;\"><iframe src=\"\/\/jsfiddle.net\/titulus_desiderio\/1o7ud866\/embedded\/\" frameborder=\"0\" allowfullscreen=\"true\" webkitallowfullscreen=\"true\" mozallowfullscreen=\"true\" style=\"top: 0px; left: 0px; width: 100%; height: 100%; position: absolute;\"><\/iframe><\/div>\n<\/div>\n<\/div>\n<p>  <\/p>\n<h2 id=\"oop-podhod\">\u041e\u041e\u041f \u043f\u043e\u0434\u0445\u043e\u0434<\/h2>\n<p>  <\/p>\n<p>\u0412 \u043f\u0440\u0435\u0434\u044b\u0434\u0443\u0449\u0438\u0439 \u0440\u0430\u0437 \u043c\u044b \u0431\u044b\u043b\u0438 \u0441\u043a\u043e\u0432\u0430\u043d\u044b \u043d\u0435\u0432\u043e\u0437\u043c\u043e\u0436\u043d\u043e\u0441\u0442\u044c\u044e \u0445\u0440\u0430\u043d\u0438\u0442\u044c \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u044f, \u0438\u0437-\u0437\u0430 \u0447\u0435\u0433\u043e \u0442\u0440\u0435\u0431\u043e\u0432\u0430\u043b\u0438 \u043e\u0442 \u043a\u043b\u0438\u0435\u043d\u0442\u0441\u043a\u043e\u0433\u043e \u043a\u043e\u0434\u0430 \u0441\u043e\u0437\u0434\u0430\u043d\u0438\u044f \u0438 \u043f\u043e\u0434\u0434\u0435\u0440\u0436\u043a\u0438 \u043e\u043a\u0440\u0443\u0436\u0435\u043d\u0438\u044f, \u043d\u0443\u0436\u043d\u043e\u0433\u043e \u043d\u0430\u0448\u0435\u043c\u0443 \u041b\u043e\u0433\u0433\u0435\u0440\u0443 \u0434\u043b\u044f \u0440\u0430\u0431\u043e\u0442\u044b. \u0412 \u041e\u041e\u041f \u0441\u0442\u0438\u043b\u0435 \u043c\u044b \u043c\u043e\u0436\u0435\u043c \u0441\u043f\u0440\u044f\u0442\u0430\u0442\u044c \u0432\u0441\u0451 \u044d\u0442\u043e &quot;\u043f\u043e\u0434 \u043a\u0430\u043f\u043e\u0442&quot; \u2014 \u0432 \u0441\u0432\u043e\u0439\u0441\u0442\u0432\u0430 \u044d\u043a\u0437\u0435\u043c\u043f\u043b\u044f\u0440\u043e\u0432 \u0438\u043b\u0438 \u043a\u043b\u0430\u0441\u0441\u043e\u0432.<\/p>\n<p>  <\/p>\n<p>\u0421\u043e\u0437\u0434\u0430\u0434\u0438\u043c \u0430\u0431\u0441\u0442\u0440\u0430\u043a\u0442\u043d\u044b\u0439 \u043a\u043b\u0430\u0441\u0441, \u0432 \u043a\u043e\u0442\u043e\u0440\u043e\u043c, \u0434\u043b\u044f \u0443\u0434\u043e\u0431\u0441\u0442\u0432\u0430 \u0440\u0430\u0431\u043e\u0442\u044b \u0441 \u043d\u0430\u0448\u0438\u043c \u041b\u043e\u0433\u0433\u0435\u0440\u043e\u043c, \u043e\u043f\u0438\u0448\u0435\u043c \u0432\u044b\u0441\u043e\u043a\u043e\u0443\u0440\u043e\u0432\u043d\u0435\u0432\u044b\u0435 \u043c\u0435\u0442\u043e\u0434\u044b: <code>log<\/code>, <code>warn<\/code> \u0438 <code>error<\/code>.<br \/>  \u041a\u0440\u043e\u043c\u0435 \u0442\u043e\u0433\u043e, \u043d\u0430\u043c \u043f\u043e\u043d\u0430\u0434\u043e\u0431\u0438\u0442\u0441\u044f \u0441\u0432\u043e\u0439\u0441\u0442\u0432\u043e <code>count<\/code> <em>(\u044f \u0441\u0434\u0435\u043b\u0430\u043b \u0435\u0433\u043e \u0441\u0432\u043e\u0439\u0441\u0442\u0432\u043e\u043c \u043f\u0440\u043e\u0442\u043e\u0442\u0438\u043f\u0430 <code>Logger<\/code> \u0438 \u043e\u0431\u044a\u0435\u043a\u0442\u043e\u043c, \u0447\u0442\u043e \u0431\u044b \u043e\u043d\u043e \u0431\u044b\u043b\u043e \u0433\u043b\u043e\u0431\u0430\u043b\u044c\u043d\u044b\u043c, \u0438 \u0441\u0430\u0431\u043a\u043b\u0430\u0441\u0441\u044b \u0441 \u044d\u043a\u0437\u0435\u043c\u043f\u043b\u044f\u0440\u0430\u043c\u0438 \u043f\u0440\u043e\u0442\u043e\u0442\u0438\u043f\u043d\u043e \u043d\u0430\u0441\u043b\u0435\u0434\u043e\u0432\u0430\u043b\u0438 \u0435\u0433\u043e, \u0430 \u043d\u0435 \u0441\u043e\u0437\u0434\u0430\u0432\u0430\u043b\u0438 \u0441\u0432\u043e\u044e \u043a\u043e\u043f\u0438\u044e. \u041d\u0430\u043c \u0436\u0435 \u043d\u0435 \u043d\u0443\u0436\u043d\u044b \u0440\u0430\u0437\u043d\u044b\u0435 \u0441\u0447\u0451\u0442\u0447\u0438\u043a\u0438 \u0434\u043b\u044f \u0440\u0430\u0437\u043d\u044b\u0445 destination?)<\/em><\/p>\n<p>  <\/p>\n<pre><code>class Logger {     log(msg) {this.write('log',msg);}     warn(msg) {this.write('warn',msg);}     error(msg) {this.write('error',msg);} }; Logger.prototype.count = {value:0};<\/code><\/pre>\n<p>  <\/p>\n<p>\u0438 2 &quot;\u0440\u0430\u0431\u043e\u0447\u0438\u0445 \u043b\u043e\u0448\u0430\u0434\u043a\u0438&quot; \u043a\u0430\u043a \u0438 \u0432 \u043f\u0440\u043e\u0448\u043b\u044b\u0439 \u0440\u0430\u0437:<\/p>\n<p>  <\/p>\n<pre><code>class LogToConsole extends Logger {     write(lvl, msg) {console[lvl](`${this.count.value++}: ${msg}`);} }; class LogToDOM extends Logger {     constructor(node) {         super();         this.domNode = node;     }     write(lvl,msg) {this.domNode.innerHTML += `&lt;div class=&quot;${lvl}&quot;&gt;${this.count.value++}: ${msg}&lt;\/div&gt;`;} };<\/code><\/pre>\n<p>  <\/p>\n<p>\u0422\u0435\u043f\u0435\u0440\u044c \u043d\u0430\u043c \u043e\u0441\u0442\u0430\u0451\u0442\u0441\u044f \u043b\u0438\u0448\u044c \u043f\u0435\u0440\u0435\u043e\u043f\u0440\u0435\u0434\u0435\u043b\u044f\u0442\u044c \u044d\u043a\u0437\u0435\u043c\u043f\u043b\u044f\u0440 \u041b\u043e\u0433\u0433\u0435\u0440\u0430, \u0441\u043e\u0437\u0434\u0430\u0432\u0430\u044f \u0435\u0433\u043e \u043e\u0442 \u0440\u0430\u0437\u043d\u044b\u0445 \u043a\u043b\u0430\u0441\u0441\u043e\u0432, \u0447\u0442\u043e \u0431\u044b \u0438\u0437\u043c\u0435\u043d\u0438\u0442\u044c destination:<\/p>\n<p>  <\/p>\n<pre><code>let logger = new LogToConsole; logger.log('this goes to console'); logger = new LogToDOM(document.querySelector('#log')); logger.log('this goes to dom');<\/code><\/pre>\n<p>  <\/p>\n<p>\u042d\u0442\u043e\u0442 \u0432\u0430\u0440\u0438\u0430\u043d\u0442 \u0443\u0436\u0435 \u043d\u0435 \u043e\u0431\u043b\u0430\u0434\u0430\u0435\u0442 \u043d\u0435\u0434\u043e\u0441\u0442\u0430\u0442\u043a\u043e\u043c \u0444\u0443\u043d\u043a\u0446\u0438\u043e\u043d\u0430\u043b\u044c\u043d\u043e \u043f\u043e\u0434\u0445\u043e\u0434\u0430 \u2014 \u043f\u043e\u0437\u0432\u043e\u043b\u044f\u0435\u0442 \u043f\u0438\u0441\u0430\u0442\u044c destination \u043d\u0435\u0437\u0430\u0432\u0438\u0441\u0438\u043c\u043e. \u041d\u043e, \u0432 \u0441\u0432\u043e\u044e \u043e\u0447\u0435\u0440\u0435\u0434\u044c, \u043d\u0435 \u0443\u0434\u043e\u0432\u043b\u0435\u0442\u0432\u043e\u0440\u044f\u0435\u0442 \u043f\u043e\u0441\u043b\u0435\u0434\u043d\u0435\u043c\u0443 \u0443\u0441\u043b\u043e\u0432\u0438\u044e: <em>\u0418\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u043d\u0435\u0437\u0430\u0432\u0438\u0441\u0438\u043c\u044b\u0445 \u041b\u043e\u0433\u0433\u0435\u0440\u043e\u0432.<\/em> \u0422\u0430\u043a \u043a\u0430\u043a \u0445\u0440\u0430\u043d\u0438\u0442 <code>count<\/code> \u0432 \u0441\u0442\u0430\u0442\u0438\u0447\u0435\u0441\u043a\u043e\u043c \u0441\u0432\u043e\u0439\u0441\u0442\u0432\u0435 \u043a\u043b\u0430\u0441\u0441\u0430 <code>Logger<\/code>. \u0410 \u0437\u043d\u0430\u0447\u0438\u0442 \u0432\u0441\u0435 \u044d\u043a\u0437\u0435\u043c\u043f\u043b\u044f\u0440\u044b \u0431\u0443\u0434\u0443\u0442 \u0438\u043c\u0435\u0442\u044c \u043e\u0434\u0438\u043d \u043e\u0431\u0449\u0438\u0439 <code>count<\/code>.<\/p>\n<p>  <\/p>\n<p>\u0420\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442. <em>\u0412\u043a\u043b\u044e\u0447\u0438\u0442\u0435 DevTools console \u043f\u0435\u0440\u0435\u0434 \u043f\u0435\u0440\u0435\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u0435\u043c \u043d\u0430 \u0432\u043a\u043b\u0430\u0434\u043a\u0443 Result<\/em><\/p>\n<p>  <\/p>\n<div class=\"oembed\">\n<div>\n<div style=\"left: 0px; width: 100%; height: 0px; position: relative; padding-bottom: 56.25%;\"><iframe src=\"\/\/jsfiddle.net\/titulus_desiderio\/6Lsfbctr\/embedded\/\" frameborder=\"0\" allowfullscreen=\"true\" webkitallowfullscreen=\"true\" mozallowfullscreen=\"true\" style=\"top: 0px; left: 0px; width: 100%; height: 100%; position: absolute;\"><\/iframe><\/div>\n<\/div>\n<\/div>\n<p>  <\/p>\n<h1 id=\"strategiya\">\u0421\u0442\u0440\u0430\u0442\u0435\u0433\u0438\u044f<\/h1>\n<p>  <\/p>\n<p>\u041d\u0430 \u0441\u0430\u043c\u043e\u043c \u0434\u0435\u043b\u0435 \u044f \u0441\u0445\u0438\u0442\u0440\u0438\u043b, \u0441\u043e\u0441\u0442\u0430\u0432\u043b\u044f\u044f \u0443\u0441\u043b\u043e\u0432\u0438\u044f \u0437\u0430\u0434\u0430\u0447\u0438: \u041b\u044e\u0431\u043e\u0435 \u0440\u0435\u0448\u0435\u043d\u0438\u0435, \u0443\u0434\u043e\u0432\u043b\u0435\u0442\u0432\u043e\u0440\u044f\u044e\u0449\u0435\u0435 \u0438\u043c \u0432\u0441\u0435\u043c \u2014 \u0431\u0443\u0434\u0435\u0442 \u0440\u0435\u0430\u043b\u0438\u0437\u043e\u0432\u044b\u0432\u0430\u0442\u044c \u043f\u0430\u0442\u0442\u0435\u0440\u043d \u0421\u0442\u0440\u0430\u0442\u0435\u0433\u0438\u044f \u0432 \u0442\u043e\u043c \u0438\u043b\u0438 \u0438\u043d\u043e\u043c \u0432\u0438\u0434\u0435. \u0412\u0435\u0434\u044c \u0435\u0433\u043e \u043e\u0441\u043d\u043e\u0432\u043d\u0430\u044f \u0438\u0434\u0435\u044f \u2014 \u043e\u0440\u0433\u0430\u043d\u0438\u0437\u043e\u0432\u0430\u0442\u044c \u043a\u043e\u0434 \u0442\u0430\u043a, \u0447\u0442\u043e \u0431\u044b \u0432\u044b\u0434\u0435\u043b\u0438\u0442\u044c \u0440\u0435\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u044e \u043a\u0430\u043a\u0438\u0445-\u043b\u0438\u0431\u043e \u043c\u0435\u0442\u043e\u0434\u043e\u0432 (\u043e\u0431\u044b\u0447\u043d\u043e &quot;\u0432\u043d\u0443\u0442\u0440\u0435\u043d\u043d\u0438\u0445&quot;) \u0432 \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u0443\u044e, \u0430\u0431\u0441\u043e\u043b\u044e\u0442\u043d\u043e \u043d\u0435\u0437\u0430\u0432\u0438\u0441\u0438\u043c\u0443\u044e \u0441\u0443\u0449\u043d\u043e\u0441\u0442\u044c. \u0422\u0430\u043a\u0438\u043c \u043e\u0431\u0440\u0430\u0437\u043e\u043c, \u0447\u0442\u043e \u0431\u044b<\/p>\n<p>  <\/p>\n<ul>\n<li>\u0432\u043e-\u043f\u0435\u0440\u0432\u044b\u0445, \u0441\u043e\u0437\u0434\u0430\u043d\u0438\u0435 \u043d\u043e\u0432\u044b\u0445 \u0432\u0430\u0440\u0438\u0430\u0446\u0438\u0439 \u044d\u0442\u043e\u0439 \u0441\u0443\u0449\u043d\u043e\u0441\u0442\u0438 \u043d\u0435 \u0437\u0430\u0442\u0440\u0430\u0433\u0438\u0432\u0430\u043b\u043e \u043e\u0441\u043d\u043e\u0432\u043d\u043e\u0439 \u043a\u043e\u0434<\/li>\n<li>\u0432\u043e-\u0432\u0442\u043e\u0440\u044b\u0445, \u043f\u043e\u0434\u0434\u0435\u0440\u0436\u0438\u0432\u0430\u0442\u044c &quot;\u0433\u043e\u0440\u044f\u0447\u0443\u044e&quot; (plug-n-play) \u0437\u0430\u043c\u0435\u043d\u0443 \u044d\u0442\u0438\u0445 \u0441\u0443\u0449\u043d\u043e\u0441\u0442\u0435\u0439 \u0443\u0436\u0435 \u0432\u043e \u0432\u0440\u0435\u043c\u044f \u0438\u0441\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u044f \u043a\u043e\u0434\u0430.<\/li>\n<\/ul>\n<p>  <\/p>\n<h2 id=\"strategiya-na-gryaznyh-funkciyah\">\u0421\u0442\u0440\u0430\u0442\u0435\u0433\u0438\u044f \u043d\u0430 &quot;\u0433\u0440\u044f\u0437\u043d\u044b\u0445&quot; \u0444\u0443\u043d\u043a\u0446\u0438\u044f\u0445<\/h2>\n<p>  <\/p>\n<p>\u0415\u0441\u043b\u0438 \u043e\u0442\u043a\u0430\u0437\u0430\u0442\u044c\u0441\u044f \u043e\u0442 \u0447\u0438\u0441\u0442\u043e\u0442\u044b \u0444\u0443\u043d\u043a\u0446\u0438\u0438 <code>Logger<\/code>, \u0438 \u0432\u043e\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c\u0441\u044f \u0437\u0430\u043c\u044b\u043a\u0430\u043d\u0438\u0435\u043c \u2014 \u043c\u044b \u043f\u043e\u043b\u0443\u0447\u0438\u043c \u0432\u043e\u0442 \u0442\u0430\u043a\u043e\u0435 \u0440\u0435\u0448\u0435\u043d\u0438\u0435:<\/p>\n<p>  <\/p>\n<pre><code>const Logger = () =&gt; {     var logCount = 0;     var logDestination;     return (destination,...args) =&gt; {         if (destination) logDestination = (lvl,msg) =&gt; destination(lvl,logCount,msg,...args);         return (lvl,msg) =&gt; logCount = logDestination(lvl,msg);     }; };<\/code><\/pre>\n<p>  <\/p>\n<p>\u0424\u0443\u043d\u043a\u0446\u0438\u0438 <code>logToConsole<\/code> \u0438 <code>logToDOM<\/code> \u043e\u0441\u0442\u0430\u044e\u0442\u0441\u044f \u043f\u0440\u0435\u0436\u043d\u0438\u043c\u0438. \u041e\u0441\u0442\u0430\u0451\u0442\u0441\u044f \u043b\u0438\u0448\u044c \u043e\u0431\u044a\u044f\u0432\u0438\u0442\u044c \u044d\u043a\u0437\u0435\u043c\u043f\u043b\u044f\u0440 \u041b\u043e\u0433\u0433\u0435\u0440\u0430. \u0410 \u0434\u043b\u044f \u0437\u0430\u043c\u0435\u043d\u044b destination \u2014 \u043f\u0435\u0440\u0435\u0434\u0430\u0432\u0430\u0442\u044c \u043d\u0443\u0436\u043d\u044b\u0439 \u044d\u0442\u043e\u043c\u0443 \u044d\u043a\u0437\u0435\u043c\u043f\u043b\u044f\u0440\u0443.<\/p>\n<p>  <\/p>\n<pre><code>const logger = Logger(); logger(logToConsole)('log','this goes to console'); logger(logToDOM,document.querySelector('#log')); logger()('log','this goes to dom');<\/code><\/pre>\n<p>  <\/p>\n<p>\u0420\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442. <em>\u0412\u043a\u043b\u044e\u0447\u0438\u0442\u0435 DevTools console \u043f\u0435\u0440\u0435\u0434 \u043f\u0435\u0440\u0435\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u0435\u043c \u043d\u0430 \u0432\u043a\u043b\u0430\u0434\u043a\u0443 Result<\/em><\/p>\n<p>  <\/p>\n<div class=\"oembed\">\n<div>\n<div style=\"left: 0px; width: 100%; height: 0px; position: relative; padding-bottom: 56.25%;\"><iframe src=\"\/\/jsfiddle.net\/titulus_desiderio\/9y4bdr24\/embedded\/\" frameborder=\"0\" allowfullscreen=\"true\" webkitallowfullscreen=\"true\" mozallowfullscreen=\"true\" style=\"top: 0px; left: 0px; width: 100%; height: 100%; position: absolute;\"><\/iframe><\/div>\n<\/div>\n<\/div>\n<p>  <\/p>\n<h2 id=\"strategiya-na-prototipah\">\u0421\u0442\u0440\u0430\u0442\u0435\u0433\u0438\u044f \u043d\u0430 \u043f\u0440\u043e\u0442\u043e\u0442\u0438\u043f\u0430\u0445<\/h2>\n<p>  <\/p>\n<p>\u041f\u043e\u0434 \u043f\u0440\u043e\u0448\u043b\u044b\u043c \u043f\u043e\u0441\u0442\u043e\u043c, \u0442\u043e\u0432\u0430\u0440\u0438\u0449 <a href=\"https:\/\/habrahabr.ru\/users\/tenshi\/\" class=\"user_link\">tenshi<\/a> \u0432\u044b\u0441\u043a\u0430\u0437\u0430\u043b \u043c\u044b\u0441\u043b\u044c:<\/p>\n<p>  <\/p>\n<blockquote><p>\u0418 \u0447\u0442\u043e \u0436\u0435 \u043c\u0435\u0448\u0430\u0435\u0442 \u0441\u043c\u0435\u043d\u0438\u0442\u044c LocalPassport \u043d\u0430 FaceBookPassport \u0432\u043e \u0432\u0440\u0435\u043c\u044f \u0440\u0430\u0431\u043e\u0442\u044b?<\/p><\/blockquote>\n<p>\u0427\u0435\u043c \u043f\u043e\u0434\u043a\u0438\u043d\u0443\u043b \u0438\u0434\u0435\u044e \u0434\u043b\u044f \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u0439 \u0440\u0435\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u0438. \u041f\u0440\u043e\u0442\u043e\u0442\u0438\u043f\u043d\u043e\u0435 \u043d\u0430\u0441\u043b\u0435\u0434\u043e\u0432\u0430\u043d\u0438\u0435 \u2014 \u0443\u0434\u0438\u0432\u0438\u0442\u0435\u043b\u044c\u043d\u043e \u043c\u043e\u0449\u043d\u0430\u044f \u0438 \u0433\u0438\u0431\u043a\u0430\u044f \u0448\u0442\u0443\u043a\u0430. \u0410 \u0441 \u043b\u0435\u0433\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u0435\u0439 \u0441\u0432\u043e\u0439\u0441\u0442\u0432\u0430 <code>.__proto__<\/code> \u2014 \u043f\u0440\u043e\u0441\u0442\u043e \u0432\u043e\u043b\u0448\u0435\u0431\u043d\u0430\u044f. \u041c\u044b \u043c\u043e\u0436\u0435\u043c \u043d\u0430-\u0445\u043e\u0434\u0443 \u043c\u0435\u043d\u044f\u0442\u044c \u043a\u043b\u0430\u0441\u0441 (\u043f\u0440\u043e\u0442\u043e\u0442\u0438\u043f) \u043e\u0442 \u043a\u043e\u0442\u043e\u0440\u043e\u0433\u043e \u043d\u0430\u0441\u043b\u0435\u0434\u0443\u0435\u0442\u0441\u044f \u043d\u0430\u0448 \u044d\u043a\u0437\u0435\u043c\u043f\u043b\u044f\u0440.<\/p>\n<p>  <\/p>\n<p>\u0412\u043e\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u043c\u0441\u044f \u044d\u0442\u043e\u0439 \u043c\u0430\u0445\u0438\u043d\u0430\u0446\u0438\u0435\u0439:<\/p>\n<p>  <\/p>\n<pre><code>class Logger {       constructor(destination) {           this.count = 0;           if (destination) this.setDestination(destination);     }     setDestination(destination) {         this.__proto__ = destination.prototype;     };     log(msg) {this.write('log',msg);}     warn(msg) {this.write('warn',msg);}     error(msg) {this.write('error',msg);} };<\/code><\/pre>\n<p>  <\/p>\n<p>\u0414\u0430, \u0442\u0435\u043f\u0435\u0440\u044c \u043c\u044b \u043c\u043e\u0436\u0435\u043c \u0447\u0435\u0441\u0442\u043d\u043e \u043f\u043e\u043c\u0435\u0449\u0430\u0442\u044c <code>count<\/code> \u0432 \u043a\u0430\u0436\u0434\u044b\u0439 \u044d\u043a\u0437\u0435\u043c\u043f\u043b\u044f\u0440 \u041b\u043e\u0433\u0433\u0435\u0440\u0430.<\/p>\n<p>  <\/p>\n<p><code>LogToConsole<\/code> \u0431\u0443\u0434\u0435\u0442 \u043e\u0442\u043b\u0438\u0447\u0430\u0442\u044c\u0441\u044f \u0442\u043e\u043b\u044c\u043a\u043e \u0432\u044b\u0437\u043e\u0432\u043e\u043c <code>this.count<\/code> \u0432\u043c\u0435\u0441\u0442\u043e <code>this.count.value<\/code>. \u0410 \u0432\u043e\u0442 <code>LogToDom<\/code> \u0438\u0437\u043c\u0435\u043d\u0438\u0442\u0441\u044f \u0437\u043d\u0430\u0447\u0438\u0442\u0435\u043b\u044c\u043d\u0435\u0435. \u0422\u0435\u043f\u0435\u0440\u044c \u043c\u044b \u043d\u0435 \u043c\u043e\u0436\u0435\u043c \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c <code>constructor<\/code> \u0434\u043b\u044f \u0437\u0430\u0434\u0430\u043d\u0438\u044f <code>.domNode<\/code>, \u0432\u0435\u0434\u044c \u043c\u044b \u043d\u0435 \u0431\u0443\u0434\u0435\u043c \u0441\u043e\u0437\u0434\u0430\u0432\u0430\u0442\u044c \u044d\u043a\u0437\u0435\u043c\u043f\u043b\u044f\u0440 \u044d\u0442\u043e\u0433\u043e \u043a\u043b\u0430\u0441\u0441\u0430. \u0421\u0434\u0435\u043b\u0430\u0435\u043c \u0434\u043b\u044f \u044d\u0442\u043e\u0433\u043e \u043c\u0435\u0442\u043e\u0434 \u0441\u0435\u0442\u0442\u0435\u0440 <code>.setDomNode(node)<\/code>:<\/p>\n<p>  <\/p>\n<pre><code>class LogToDOM extends Logger {     write(lvl,msg) {this.domNode.innerHTML += `&lt;div class=&quot;${lvl}&quot;&gt;${this.count++}: ${msg}&lt;\/div&gt;`;}     setDomNode(node) {this.domNode = node;} };<\/code><\/pre>\n<p>  <\/p>\n<p>\u0422\u0435\u043f\u0435\u0440\u044c \u0434\u043b\u044f \u0441\u043c\u0435\u043d\u044b destination \u043d\u0443\u0436\u043d\u043e \u0432\u044b\u0437\u0432\u0430\u0442\u044c \u043c\u0435\u0442\u043e\u0434 <code>setDestination<\/code> \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0437\u0430\u043c\u0435\u043d\u0438\u0442 \u043f\u0440\u043e\u0442\u043e\u0442\u0438\u043f \u043d\u0430\u0448\u0435\u0433\u043e \u044d\u043a\u0437\u0435\u043c\u043f\u043b\u044f\u0440\u0430:<\/p>\n<p>  <\/p>\n<pre><code>const logger = new Logger(); logger.setDestination(LogToConsole); logger.log('this goes to console'); logger.setDestination(LogToDOM); logger.setDomNode(document.querySelector('#log')); logger.log('this goes to dom');<\/code><\/pre>\n<p>  <\/p>\n<p>\u0420\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442. <em>\u0412\u043a\u043b\u044e\u0447\u0438\u0442\u0435 DevTools console \u043f\u0435\u0440\u0435\u0434 \u043f\u0435\u0440\u0435\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u0435\u043c \u043d\u0430 \u0432\u043a\u043b\u0430\u0434\u043a\u0443 Result<\/em><\/p>\n<p>  <\/p>\n<div class=\"oembed\">\n<div>\n<div style=\"left: 0px; width: 100%; height: 0px; position: relative; padding-bottom: 56.25%;\"><iframe src=\"\/\/jsfiddle.net\/titulus_desiderio\/jadfjpyr\/embedded\/\" frameborder=\"0\" allowfullscreen=\"true\" webkitallowfullscreen=\"true\" mozallowfullscreen=\"true\" style=\"top: 0px; left: 0px; width: 100%; height: 100%; position: absolute;\"><\/iframe><\/div>\n<\/div>\n<\/div>\n<p>  <\/p>\n<h2 id=\"strategiya-na-interfeysah\">\u0421\u0442\u0440\u0430\u0442\u0435\u0433\u0438\u044f \u043d\u0430 \u0438\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441\u0430\u0445<\/h2>\n<p>  <\/p>\n<p>\u0415\u0441\u043b\u0438 \u0432\u044b \u0437\u0430\u0433\u0443\u0433\u043b\u0438\u0442\u0435 &quot;\u041f\u0430\u0442\u0442\u0435\u0440\u043d \u0421\u0442\u0440\u0430\u0442\u0435\u0433\u0438\u044f&quot; \u0442\u043e \u0432 \u043b\u044e\u0431\u043e\u0439* \u0438\u0437 \u0441\u0442\u0430\u0442\u0435\u0439 \u0432\u044b \u0432\u0441\u0442\u0440\u0435\u0442\u0438\u0442\u0435 \u0443\u043f\u043e\u043c\u0438\u043d\u0430\u043d\u0438\u0435 \u0438\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441\u043e\u0432. \u0418 \u0442\u0430\u043a \u043f\u043e\u043b\u0443\u0447\u0438\u043b\u043e\u0441\u044c, \u0447\u0442\u043e \u0432 \u043b\u044e\u0431\u043e\u043c* \u0434\u0440\u0443\u0433\u043e\u043c \u044f\u0437\u044b\u043a\u0435: \u0438\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441 \u2014 \u044d\u0442\u043e \u043a\u043e\u043d\u043a\u0440\u0435\u0442\u043d\u0430\u044f \u0441\u0438\u043d\u0442\u0430\u043a\u0441\u0438\u0447\u0435\u0441\u043a\u0430\u044f \u043a\u043e\u043d\u0441\u0442\u0440\u0443\u043a\u0446\u0438\u044f, \u043e\u0431\u043b\u0430\u0434\u0430\u044e\u0449\u0430\u044f \u043a\u043e\u043d\u043a\u0440\u0435\u0442\u043d\u044b\u043c \u0443\u043d\u0438\u043a\u0430\u043b\u044c\u043d\u044b\u043c \u0444\u0443\u043d\u043a\u0446\u0438\u043e\u043d\u0430\u043b\u043e\u043c. \u0412 \u043e\u0442\u043b\u0438\u0447\u0438\u0435 \u043e\u0442 JS\u2026 \u041c\u043d\u0435 \u043a\u0430\u0436\u0435\u0442\u0441\u044f, \u0447\u0442\u043e \u0438\u043c\u0435\u043d\u043d\u043e \u043f\u043e \u044d\u0442\u043e\u0439 \u043f\u0440\u0438\u0447\u0438\u043d\u0435 \u043c\u043d\u0435 \u0442\u0430\u043a \u0442\u044f\u0436\u0435\u043b\u043e \u0434\u0430\u0432\u0430\u043b\u0441\u044f \u044d\u0442\u043e\u0442 \u043f\u0430\u0442\u0442\u0435\u0440\u043d \u0432 \u0441\u0432\u043e\u0451 \u0432\u0440\u0435\u043c\u044f. <em>(\u0414\u0430 \u043a\u043e\u0433\u043e \u044f \u043e\u0431\u043c\u0430\u043d\u044b\u0432\u0430\u044e? \u0434\u043e \u0441\u0438\u0445 \u043f\u043e\u0440 \u043d\u0438\u0432\u0437\u0443\u0431\u043d\u043e\u0433\u043e\u0439 \u043a\u0430\u043a \u043e\u043d\u043e \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442)<\/em>.<\/p>\n<p>  <\/p>\n<p>\u0415\u0441\u043b\u0438 \u043f\u043e-\u043f\u0440\u043e\u0441\u0442\u043e\u043c\u0443: <strong>\u0418\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441<\/strong> \u043f\u043e\u0437\u0432\u043e\u043b\u044f\u0435\u0442 &quot;\u043e\u0431\u044f\u0437\u0430\u0442\u044c&quot; \u0438\u043c\u043f\u043b\u0435\u043c\u0435\u043d\u0442\u0430\u0446\u0438\u0438 <em>(\u0440\u0435\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u0438)<\/em> \u043e\u0431\u043b\u0430\u0434\u0430\u0442\u044c \u043a\u043e\u043d\u043a\u0440\u0435\u0442\u043d\u044b\u043c\u0438 \u043c\u0435\u0442\u043e\u0434\u0430\u043c\u0438. \u041d\u0435 \u0432\u0437\u0438\u0440\u0430\u044f \u043d\u0430 \u0442\u043e, \u043a\u0430\u043a \u044d\u0442\u0438 \u043c\u0435\u0442\u043e\u0434\u044b \u0440\u0435\u0430\u043b\u0438\u0437\u043e\u0432\u0430\u043d\u044b. \u041d\u0430\u043f\u0440\u0438\u043c\u0435\u0440 \u0432 \u043a\u043b\u0430\u0441\u0441\u0435 <code>\u0427\u0435\u043b\u043e\u0432\u0435\u043a<\/code> \u043e\u0431\u044a\u044f\u0432\u043b\u0435\u043d \u0438\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441 <code>\u0420\u0435\u0447\u044c<\/code> \u0441 \u043c\u0435\u0442\u043e\u0434\u0430\u043c\u0438 <code>\u043f\u043e\u0437\u0434\u043e\u0440\u043e\u0432\u0430\u0442\u044c\u0441\u044f<\/code> \u0438 <code>\u043f\u043e\u043f\u0440\u043e\u0449\u0430\u0442\u044c\u0441\u044f<\/code>. \u0410 \u0443\u0436\u0435 \u043a\u043e\u043d\u043a\u0440\u0435\u0442\u043d\u044b\u0439 \u044d\u043a\u0437\u0435\u043c\u043f\u043b\u044f\u0440 <code>\u0432\u0430\u0441\u044f<\/code> \u043c\u043e\u0436\u0435\u0442 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u0440\u0430\u0437\u043d\u044b\u0435 \u0438\u043c\u043f\u043b\u0435\u043c\u0435\u043d\u0442\u0430\u0446\u0438\u0438 \u044d\u0442\u043e\u0433\u043e \u0438\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441\u0430: <code>\u0440\u0443\u0441\u0441\u043a\u0430\u044f<\/code>, <code>\u0430\u043d\u0433\u043b\u0438\u0439\u0441\u043a\u0430\u044f<\/code>, <code>\u0440\u0443\u0441\u0441\u043a\u0430\u044f\u041c\u0430\u0442\u0435\u0440\u043d\u0430\u044f<\/code>. \u0418 \u0434\u0430\u0436\u0435 \u043c\u0435\u043d\u044f\u0442\u044c \u0438\u0445 \u0432\u0440\u0435\u043c\u044f \u043e\u0442 \u0432\u0440\u0435\u043c\u0435\u043d\u0438. \u0422\u0430\u043a \u0447\u0442\u043e \u043f\u0440\u0438 &quot;\u0432\u043a\u043b\u044e\u0447\u0435\u043d\u043d\u043e\u0439&quot; \u0438\u043c\u043f\u043b\u0435\u043c\u0435\u043d\u0442\u0430\u0446\u0438\u0438 <code>\u0440\u0443\u0441\u0441\u043a\u0430\u044f<\/code>, \u043d\u0430\u0448 <code>\u0432\u0430\u0441\u044f<\/code> \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0432 \u043c\u0435\u0442\u043e\u0434 <code>\u043f\u043e\u0437\u0434\u043e\u0440\u043e\u0432\u0430\u0442\u044c\u0441\u044f<\/code> \u0438\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441\u0430 <code>\u0420\u0435\u0447\u044c<\/code> \u2014 \u043f\u0440\u043e\u0438\u0437\u043d\u0435\u0441\u0451\u0442 <em>&quot;\u0417\u0434\u0440\u0430\u0432\u0441\u0442\u0432\u0443\u0439\u0442\u0435&quot;<\/em>. \u0410 \u043a\u043e\u0433\u0434\u0430 &quot;\u0432\u043a\u043b\u044e\u0447\u0435\u043d\u0430&quot; <code>\u0430\u043d\u0433\u043b\u0438\u0439\u0441\u043a\u0430\u044f<\/code>, \u0442\u043e \u0436\u0435 \u0434\u0435\u0439\u0441\u0442\u0432\u0438\u0435 \u043f\u043e\u0431\u0443\u0434\u0438\u0442 \u0435\u0433\u043e \u0441\u043a\u0430\u0437\u0430\u0442\u044c <em>&#8216;Hello&#8217;<\/em>.<\/p>\n<p>  <\/p>\n<p>\u042f \u043d\u0435 \u043c\u043e\u0433 \u0443\u0434\u0435\u0440\u0436\u0430\u0442\u044c\u0441\u044f \u043e\u0442 \u043f\u0440\u0438\u0432\u0435\u0434\u0435\u043d\u0438\u044f \u043f\u0440\u0438\u043c\u0435\u0440\u0430 \u044d\u0442\u043e\u0433\u043e \u043f\u0430\u0442\u0442\u0435\u0440\u043d\u0430 \u0432 \u0435\u0433\u043e &quot;\u043a\u043b\u0430\u0441\u0441\u0438\u0447\u0435\u0441\u043a\u043e\u043c&quot; \u0432\u0438\u0434\u0435, \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044e\u0449\u0435\u043c \u0438\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441\u044b. \u0414\u043b\u044f \u0447\u0435\u0433\u043e \u043d\u0430\u0431\u0440\u043e\u0441\u0430\u043b \u043d\u0435\u0431\u043e\u043b\u044c\u0448\u0443\u044e \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0443 \u0440\u0435\u0430\u043b\u0438\u0437\u0443\u044e\u0449\u0443\u044e \u043a\u043e\u043d\u0446\u0435\u043f\u0446\u0438\u044e \u0438\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441\u043e\u0432 \u0432 JS \u2014 <a href=\"https:\/\/github.com\/titulus\/js-interface\">js-interface<\/a> <a href=\"https:\/\/www.npmjs.com\/package\/js-interface\">npm<\/a><\/p>\n<p>  <\/p>\n<div class=\"spoiler\"><b class=\"spoiler_title\">\u0421\u043e\u0432\u0441\u0435\u043c \u043a\u0440\u0430\u0442\u0435\u043d\u044c\u043a\u0438\u0439 \u043b\u0438\u043a\u0431\u0435\u0437 \u043f\u043e \u0442\u043e\u043c\u0443 \u0441\u0438\u043d\u0442\u0430\u043a\u0441\u0438\u0441\u0443 \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0431\u0443\u0434\u0435\u0442 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d \u0432 \u043f\u0440\u0438\u043c\u0435\u0440\u0435:<\/b><\/p>\n<div class=\"spoiler_text\">\n<pre><code>const MyInterface = new jsInterface(['doFirst','doSecond']); \/\/ \u0441\u043e\u0437\u0434\u0430\u0451\u0442 \u0418\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441 \u043e\u0431\u044a\u044f\u0432\u043b\u044f\u044e\u0449\u0438\u0439 \u043c\u0435\u0442\u043e\u0434\u044b .doFirst(..) \u0438 .doSecond(..)  MyInterface(object,'prop'); \/\/ \u043d\u0430\u0437\u043d\u0430\u0447\u0430\u0435\u0442 \u0441\u0432\u043e\u0439\u0441\u0442\u0432\u0443 .prop \u044d\u0442\u043e\u0442 \u0438\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441. \/\/ \u0442\u0435\u043f\u0435\u0440\u044c Object.keys(object.prop) -&gt; ['doFirst','doSecond'] \u0432\u0441\u0435\u0433\u0434\u0430*  object.prop = implementation; \/\/ \u0443\u043a\u0430\u0437\u044b\u0432\u0430\u0435\u0442\/\u0437\u0430\u0434\u0430\u0451\u0442 \u0438\u043c\u043f\u043b\u0435\u043c\u0435\u043d\u0442\u0430\u0446\u0438\u044e \u0434\u043b\u044f \u043c\u0435\u0442\u043e\u0434\u0430. \/\/ implementation \u043c\u043e\u0436\u0435\u0442 \u0431\u044b\u0442\u044c \u043a\u0430\u043a \u043e\u0431\u044a\u0435\u043a\u0442\u043e\u043c. \u0442\u0430\u043a \u0438 \u043a\u043e\u043d\u0441\u0442\u0440\u0443\u043a\u0442\u043e\u0440\u043e\u043c - \u0433\u043b\u0430\u0432\u043d\u043e\u0435, \u0447\u0442\u043e \u0431\u044b \u043c\u0435\u0442\u043e\u0434\u044b doFirst \u0438 doSecond \u0438\u043c\u0435\u043b\u043e.<\/code><\/pre>\n<\/div>\n<\/div>\n<p>  <\/p>\n<p>\u042d\u0442\u043e\u0442 \u043f\u043e\u0434\u0445\u043e\u0434 \u0431\u0443\u0434\u0435\u0442 \u0432\u0435\u0441\u044c\u043c\u0430 \u0431\u043b\u0438\u0437\u043e\u043a \u043a \u043f\u0440\u0435\u0434\u044b\u0434\u0443\u0449\u0435\u043c\u0443. \u0412 \u043a\u043e\u0434\u0435 <code>Logger<\/code> \u0442\u043e\u043b\u044c\u043a\u043e \u0441\u0442\u0440\u043e\u043a\u0438 \u0441\u0432\u044f\u0437\u0430\u043d\u043d\u044b\u0435 \u0441 <code>destination<\/code> \u0437\u0430\u043c\u0435\u043d\u044f\u0442\u0441\u044f \u043e\u0434\u043d\u043e\u0439 \u0441 jsInterface, \u0430 \u043c\u0435\u0442\u043e\u0434 <code>write<\/code> \u043f\u0435\u0440\u0435\u043d\u0435\u0441\u0451\u0442\u0441\u044f \u043a \u0441\u0432\u043e\u0439\u0441\u0442\u0432\u0443 <code>loginterface<\/code>:<\/p>\n<p>  <\/p>\n<pre><code>class Logger {     constructor() {         this.count = 0;         jsInterface(['write'])(this,'loginterface');     }     log(msg) { return this.loginterface.write('log',msg); }     warn(msg) { return this.loginterface.write('warn',msg); }     error(msg) { return this.loginterface.write('error',msg); } };<\/code><\/pre>\n<p>  <\/p>\n<p>\u041f\u043e\u044f\u0441\u043d\u044e \u043a\u043e\u0434 \u0432\u044b\u0448\u0435. \u0412 \u043a\u043e\u043d\u0441\u0442\u0440\u0443\u043a\u0442\u043e\u0440\u0435 \u043c\u044b \u043e\u0431\u044a\u044f\u0432\u043b\u044f\u0435\u043c \u0443 \u044d\u043a\u0437\u0435\u043c\u043f\u043b\u044f\u0440\u0430 <code>new Logger<\/code> <del>\u0441\u0432\u043e\u0439\u0441\u0442\u0432\u043e<\/del> \u0438\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441 <code>loginterface<\/code> \u0441 \u043c\u0435\u0442\u043e\u0434\u043e\u043c <code>write<\/code>.<br \/>  <code>LogToConsole<\/code> \u043d\u0435 \u0442\u0440\u0435\u0431\u0443\u0435\u0442 \u0434\u043b\u044f \u0441\u0435\u0431\u044f \u0445\u0440\u0430\u043d\u0435\u043d\u0438\u044f \u043a\u0430\u043a\u0438\u0445-\u043b\u0438\u0431\u043e \u0434\u0430\u043d\u043d\u044b\u0445, \u0442\u0430\u043a \u0447\u0442\u043e \u0441\u0434\u0435\u043b\u0430\u0435\u043c \u0435\u0433\u043e \u043f\u0440\u043e\u0441\u0442\u044b\u043c \u043e\u0431\u044a\u0435\u043a\u0442\u043e\u043c <code>log2console<\/code> \u0441 \u043c\u0435\u0442\u043e\u0434\u043e\u043c <code>write<\/code>:<\/p>\n<p>  <\/p>\n<pre><code>const log2console = {     write:function(lvl,msg) {console[lvl](`${this.count++}: ${msg}`);} };<\/code><\/pre>\n<p>  <\/p>\n<p>\u0410 \u0432\u043e\u0442 <code>LogToDOM<\/code> \u043d\u0443\u0436\u0434\u0430\u0435\u0442\u0441\u044f \u0432 \u0445\u0440\u0430\u043d\u0435\u043d\u0438\u0438 <code>node<\/code>. \u041f\u0440\u0430\u0432\u0434\u0430 \u0442\u0435\u043f\u0435\u0440\u044c \u0435\u0433\u043e \u043c\u043e\u0436\u043d\u043e \u0437\u0430\u0432\u0435\u0440\u043d\u0443\u0442\u044c \u0432 \u0437\u0430\u043c\u044b\u043a\u0430\u043d\u0438\u0435 \u0438 \u043d\u0435 \u0437\u0430\u0445\u043b\u0430\u043c\u043b\u044f\u0442\u044c \u044d\u043a\u0437\u0435\u043c\u043f\u043b\u044f\u0440 Logger \u043b\u0438\u0448\u043d\u0438\u043c\u0438 \u0441\u0432\u043e\u0439\u0441\u0442\u0432\u0430\u043c\u0438 \u0438 \u043c\u0435\u0442\u043e\u0434\u0430\u043c\u0438.<\/p>\n<p>  <\/p>\n<pre><code>function LogToDOM(node) {     this.write = function(lvl,msg) {node.innerHTML += `&lt;div class=&quot;${lvl}&quot;&gt;${this.count++}: ${msg}&lt;\/div&gt;`;} };<\/code><\/pre>\n<p>  <\/p>\n<p>\u0418\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u0435 \u0442\u043e\u0436\u0435 \u0432\u0435\u0441\u044c\u043c\u0430 \u043f\u043e\u0445\u043e\u0436\u0435 \u043d\u0430 \u043f\u0440\u0435\u0434\u044b\u0434\u0443\u0449\u0438\u0439 \u0432\u0430\u0440\u0438\u0430\u043d\u0442. \u0420\u0430\u0437\u0432\u0435 \u0447\u0442\u043e \u043d\u0435 \u043d\u0430\u0434\u043e \u0434\u043e\u043f\u043e\u043b\u043d\u0438\u0442\u0435\u043b\u044c\u043d\u043e <code>setDomNode<\/code> \u0432\u044b\u0437\u044b\u0432\u0430\u0442\u044c.<\/p>\n<p>  <\/p>\n<pre><code>const logger = new Logger(); logger.loginterface = log2console; logger.log('this goes to console'); logger.loginterface = new LogToDOM(document.querySelector('#log')); logger.log('this goes to dom');<\/code><\/pre>\n<p>  <\/p>\n<p>\u0412\u044b \u043d\u0430\u0432\u0435\u0440\u043d\u043e\u0435 \u0437\u0430\u043c\u0435\u0442\u0438\u043b\u0438 \u0442\u0430\u043a\u0443\u044e \u0441\u0442\u0440\u0430\u043d\u043d\u043e\u0441\u0442\u044c: \u041f\u043e\u0441\u043b\u0435<\/p>\n<p>  <\/p>\n<pre><code>logger.loginterface = log2console;<\/code><\/pre>\n<p>  <\/p>\n<p>\u0434\u043e\u043b\u0436\u0435\u043d c\u0431\u0438\u0432\u0430\u0442\u044c\u0441\u044f <code>this.count<\/code>. \u0432\u0435\u0434\u044c:<\/p>\n<p>  <\/p>\n<pre><code>logger.log('bla bla') -&gt; -&gt; this.loginterface.write('log','bla bla') -&gt; -&gt; log2console.write('log','bla bla') this.count === log2console.count<\/code><\/pre>\n<p>  <\/p>\n<p>\u041d\u043e \u0432 \u044d\u0442\u043e\u043c \u0438 &quot;\u043c\u0430\u0433\u0438\u044f&quot; \u0438\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441\u043e\u0432. \u0418\u043c\u043f\u043b\u0435\u043c\u0435\u043d\u0442\u0430\u0446\u0438\u0438 \u2014 \u043d\u0435 &quot;\u0441\u0430\u043c\u043e\u0441\u0442\u043e\u044f\u0442\u0435\u043b\u044c\u043d\u044b\u0435&quot; \u043e\u0431\u044a\u0435\u043a\u0442\u044b \u2014 \u043e\u043d\u0438 \u043b\u0438\u0448\u044c \u043f\u0440\u0435\u0434\u043e\u0441\u0442\u0430\u0432\u043b\u044f\u044e\u0442 \u043a\u043e\u0434 \u0441\u0432\u043e\u0438\u0445 \u043c\u0435\u0442\u043e\u0434\u043e\u0432 \u0432 \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u0435 &quot;\u043d\u0430\u0441\u0442\u043e\u044f\u0449\u0438\u043c&quot; \u043e\u0431\u044a\u0435\u043a\u0442\u0430\u043c, \u0443 \u043a\u043e\u0442\u043e\u0440\u044b\u0445 \u044d\u0442\u043e\u0442 \u0438\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441 \u043e\u0431\u044a\u044f\u0432\u043b\u0435\u043d. \u0422\u0430\u043a \u0447\u0442\u043e \u0446\u0435\u043f\u043e\u0447\u043a\u0430 \u043f\u0440\u0435\u043e\u0431\u0440\u0430\u0437\u043e\u0432\u0430\u043d\u0438\u0439 \u0431\u0443\u0434\u0435\u0442 \u0442\u0430\u043a\u0430\u044f:<\/p>\n<p>  <\/p>\n<pre><code>logger.log('bla bla') -&gt; -&gt; this.loginterface.write('log','bla bla') -&gt; -&gt; log2console.write.apply(logger,['log','bla bla']) this.count === logger.count<\/code><\/pre>\n<p>  <\/p>\n<p>\u0420\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442. <em>\u0412\u043a\u043b\u044e\u0447\u0438\u0442\u0435 DevTools console \u043f\u0435\u0440\u0435\u0434 \u043f\u0435\u0440\u0435\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u0435\u043c \u043d\u0430 \u0432\u043a\u043b\u0430\u0434\u043a\u0443 Result<\/em><\/p>\n<p>  <\/p>\n<div class=\"oembed\">\n<div>\n<div style=\"left: 0px; width: 100%; height: 0px; position: relative; padding-bottom: 56.25%;\"><iframe src=\"\/\/jsfiddle.net\/titulus_desiderio\/mapd78yv\/embedded\/\" frameborder=\"0\" allowfullscreen=\"true\" webkitallowfullscreen=\"true\" mozallowfullscreen=\"true\" style=\"top: 0px; left: 0px; width: 100%; height: 100%; position: absolute;\"><\/iframe><\/div>\n<\/div>\n<\/div>\n<p>  <\/p>\n<h1 id=\"itog\">\u0418\u0442\u043e\u0433<\/h1>\n<p>  <\/p>\n<p><em>\u0421\u0442\u0440\u0430\u0442\u0435\u0433\u0438\u044f<\/em> \u044f\u0432\u043b\u044f\u0435\u0442\u0441\u044f \u043e\u0434\u043d\u0438\u043c \u0438\u0437 \u0431\u0430\u0437\u043e\u0432\u044b\u0445 \u043f\u0430\u0442\u0442\u0435\u0440\u043d\u043e\u0432. \u0422\u0430\u043a\u0438\u043c, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0447\u0430\u0441\u0442\u043e \u0440\u0435\u0430\u043b\u0438\u0437\u0443\u0435\u0442\u0441\u044f \u0438\u043d\u0442\u0443\u0438\u0442\u0438\u0432\u043d\u043e, \u0431\u0435\u0437 \u043e\u0441\u043e\u0437\u043d\u0430\u043d\u043d\u043e\u0433\u043e \u0441\u043b\u0435\u0434\u043e\u0432\u0430\u043d\u0438\u044f \u0437\u0430\u043f\u043e\u0432\u0435\u0434\u044f\u043c \u043a\u0430\u043a\u043e\u0433\u043e-\u043b\u0438\u0431\u043e \u0443\u0447\u0435\u0431\u043d\u0438\u043a\u0430.<\/p>\n<p>  <\/p>\n<p>\u041d\u0435 \u0441\u043a\u0430\u0436\u0443 \u0437\u0430 \u0434\u0440\u0443\u0433\u0438\u0435 \u044f\u0437\u044b\u043a\u0438, \u043d\u043e JS \u0447\u0435\u0440\u0442\u043e\u0432\u0441\u043a\u0438 \u0433\u0438\u0431\u043e\u043a! \u042d\u0442\u043e\u0442, \u043a\u0430\u043a \u0438 \u0434\u0440\u0443\u0433\u0438\u0435 \u043f\u0430\u0442\u0442\u0435\u0440\u043d\u044b, \u043d\u0435 \u0437\u0430\u0448\u0438\u0442\u044b \u0432 \u0441\u0438\u043d\u0442\u0430\u043a\u0441\u0438\u0441 \u2014 \u0440\u0435\u0430\u043b\u0438\u0437\u0443\u0439\u0442\u0435 \u0435\u0433\u043e \u0442\u0430\u043a \u043a\u0430\u043a \u044d\u0442\u043e \u0443\u0434\u043e\u0431\u043d\u043e \u0438 \u0442\u0430\u043c \u0433\u0434\u0435 \u044d\u0442\u043e \u0443\u0434\u043e\u0431\u043d\u043e.<\/p>\n<p>  <\/p>\n<p>\u0420\u0430\u0437\u0443\u043c\u0435\u0435\u0442\u0441\u044f 3 \u043e\u043f\u0438\u0441\u0430\u043d\u043d\u044b\u0435 \u0432\u044b\u0448\u0435 \u2014 \u0434\u0430\u043b\u0435\u043a\u043e \u043d\u0435 \u0432\u0441\u0435 \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u044b\u0435 \u0440\u0435\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u0438 \u044d\u0442\u043e\u0433\u043e \u043f\u0430\u0442\u0442\u0435\u0440\u043d\u0430. \u042f \u0431\u043e\u043b\u0435\u0435 \u0447\u0435\u043c \u0443\u0432\u0435\u0440\u0435\u043d, \u0447\u0442\u043e \u0442\u044b, \u0447\u0438\u0442\u0430\u0442\u0435\u043b\u044c, \u0441\u043c\u043e\u0436\u0435\u0448\u044c \u0441\u0434\u0435\u043b\u0430\u0442\u044c \u0442\u043e\u0436\u0435 \u0441\u0430\u043c\u043e\u0435 \u0435\u0449\u0451 \u0434\u0435\u0441\u044f\u0442\u043a\u043e\u043c \u0434\u0440\u0443\u0433\u0438\u0445 \u0441\u043f\u043e\u0441\u043e\u0431\u043e\u0432. \u0422\u0430\u043a \u0447\u0442\u043e \u043f\u0440\u0438\u0437\u044b\u0432\u0430\u044e \u0432\u0437\u044f\u0442\u044c \u043d\u0430 \u0437\u0430\u043c\u0435\u0442\u043a\u0443 \u0438\u043c\u0435\u043d\u043d\u043e \u0438\u0434\u0435\u044e \u0421\u0442\u0440\u0430\u0442\u0435\u0433\u0438\u0438, \u0430 \u043d\u0435 \u043c\u043e\u0438 \u0436\u0430\u043b\u043a\u0438\u0435 \u043f\u043e\u043f\u044b\u0442\u043a\u0438 \u0435\u0451 \u0440\u0435\u0430\u043b\u0438\u0437\u043e\u0432\u0430\u0442\u044c.<\/p>\n<p>  <\/p>\n<hr\/>\n<p>  <\/p>\n<p><em>*\u042f \u043e\u0447\u0435\u043d\u044c \u043b\u044e\u0431\u043b\u044e <del>\u044d\u043a\u0441\u0442\u0440\u0430\u043f\u043e\u043b\u0438\u0440\u043e\u0432\u0430\u0442\u044c<\/del> \u043f\u0440\u0435\u0443\u0432\u0435\u043b\u0438\u0447\u0438\u0432\u0430\u0442\u044c<\/em><\/p>\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\/313392\/\"> https:\/\/habrahabr.ru\/post\/313392\/<\/a><\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u0420\u0430\u043d\u0435\u0435 \u044f \u0443\u0436\u0435 \u043f\u0443\u0431\u043b\u0438\u043a\u043e\u0432\u0430\u043b <a href=\"https:\/\/habrahabr.ru\/post\/191480\/\">\u043f\u0435\u0440\u0435\u0432\u043e\u0434<\/a> \u0441\u0442\u0430\u0442\u044c\u0438 \u0441 \u0442\u0430\u043a\u0438\u043c \u0436\u0435 \u043d\u0430\u0437\u0432\u0430\u043d\u0438\u0435\u043c. \u0418 \u043f\u043e\u0434 \u043d\u0435\u0439 \u0442\u043e\u0432\u0430\u0440\u0438\u0449 <a href=\"https:\/\/habrahabr.ru\/users\/atei\/\" class=\"user_link\">aTei<\/a> \u043e\u0441\u0442\u0430\u0432\u0438\u043b <a href=\"https:\/\/habrahabr.ru\/post\/191480\/#comment_6702426\">\u043a\u043e\u043c\u043c\u0435\u043d\u0442\u0430\u0440\u0438\u0439<\/a>:<\/p>\n<p>  <\/p>\n<blockquote><p>\u041f\u043e-\u043c\u043e\u0435\u043c\u0443 \u043a\u043e\u0435-\u0447\u0435\u0433\u043e \u043d\u0435 \u0445\u0432\u0430\u0442\u0430\u0435\u0442 \u0432 \u044d\u0442\u043e\u0439 \u0441\u0442\u0430\u0442\u044c\u0435 \u0438 \u0432 \u0441\u0442\u0430\u0442\u044c\u0435 \u0432 \u0432\u0438\u043a\u0438\u043f\u0435\u0434\u0438\u0435 \u2014 \u043f\u0440\u0438\u043c\u0435\u0440\u0430 \u0432 \u0441\u0442\u0438\u043b\u0435 \u00ab\u0411\u044b\u043b\u043e \u043f\u043b\u043e\u0445\u043e \u2014 \u0441\u0442\u0430\u043b\u043e \u0445\u043e\u0440\u043e\u0448\u043e\u00bb. \u0421\u0440\u0430\u0437\u0443 \u043f\u043e\u043b\u0443\u0447\u0430\u0435\u0442\u0441\u044f \u00ab\u0445\u043e\u0440\u043e\u0448\u043e\u00bb \u0438 \u043d\u0435 \u0434\u043e\u0441\u0442\u0430\u0442\u043e\u0447\u043d\u043e \u044f\u0441\u043d\u043e, \u0447\u0442\u043e \u044d\u0442\u043e \u0434\u0435\u0439\u0441\u0442\u0432\u0438\u0442\u0435\u043b\u044c\u043d\u043e \u0445\u043e\u0440\u043e\u0448\u043e. \u0411\u0443\u0434\u0443 \u0431\u043b\u0430\u0433\u043e\u0434\u0430\u0440\u0435\u043d \u0437\u0430 \u0442\u0430\u043a\u043e\u0439 \u043f\u0440\u0438\u043c\u0435\u0440.<\/p><\/blockquote>\n<p>\u041e\u0442\u0432\u0435\u0442\u0430 \u043d\u0430 \u043d\u0435\u0433\u043e \u0442\u0430\u043a \u043d\u0438\u043a\u0442\u043e \u0438 \u043d\u0435 \u0434\u0430\u043b \u0434\u043e \u0441\u0438\u0445 \u043f\u043e\u0440. \u0417\u0430 3 \u0433\u043e\u0434\u0430 \u044f \u043d\u0430\u0431\u0440\u0430\u043b\u0441\u044f <del>\u043e\u043f\u044b\u0442\u0430<\/del> \u0441\u043c\u0435\u043b\u043e\u0441\u0442\u0438 \u0438 \u0442\u0435\u043f\u0435\u0440\u044c, \u043a\u0430\u043a \u043e\u0442\u0432\u0435\u0442 \u043d\u0430 \u044d\u0442\u043e\u0442 \u043a\u043e\u043c\u043c\u0435\u043d\u0442\u0430\u0440\u0438\u0439, \u0445\u043e\u0447\u0443 \u043d\u0430\u043f\u0438\u0441\u0430\u0442\u044c \u043e \u043f\u0430\u0442\u0442\u0435\u0440\u043d\u0435 \u0421\u0442\u0440\u0430\u0442\u0435\u0433\u0438\u044f \u043e\u0442 \u0441\u0432\u043e\u0435\u0433\u043e \u0438\u043c\u0435\u043d\u0438.<\/p>\n<p>  <\/p>\n<p>\u041a\u0440\u043e\u0445\u0438 \u0442\u0435\u043e\u0440\u0438\u0438 \u0432\u0441\u0442\u0440\u0435\u0447\u0430\u044e\u0442\u0441\u044f \u0433\u0434\u0435-\u0442\u043e \u043f\u043e \u0442\u0435\u043a\u0441\u0442\u0443. \u041d\u043e \u0431\u043e\u043b\u044c\u0448\u0430\u044f \u0447\u0430\u0441\u0442\u044c \u0441\u0442\u0430\u0442\u044c\u0438 \u043f\u043e\u0441\u0432\u044f\u0449\u0435\u043d\u0430 \u043f\u0440\u0430\u043a\u0442\u0438\u0447\u0435\u0441\u043a\u0438\u043c \u0441\u043f\u043e\u0441\u043e\u0431\u0430\u043c \u043f\u0440\u0438\u043c\u0435\u043d\u0435\u043d\u0438\u044f \u044d\u0442\u043e\u0433\u043e \u043f\u0430\u0442\u0442\u0435\u0440\u043d\u0430 \u0438 \u0432\u0430\u0440\u0438\u0430\u043d\u0442\u0430\u043c \u0435\u0433\u043e \u043f\u0440\u0438\u043c\u0435\u043d\u0435\u043d\u0438\u044f \u0438\u0437\u0431\u0435\u0436\u0430\u0442\u044c.<\/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-280326","post","type-post","status-publish","format-standard","hentry"],"_links":{"self":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/280326","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=280326"}],"version-history":[{"count":0,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/280326\/revisions"}],"wp:attachment":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=280326"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=280326"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=280326"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}