{"id":179727,"date":"2013-05-14T20:12:03","date_gmt":"2013-05-14T16:12:03","guid":{"rendered":"http:\/\/savepearlharbor.com\/?p=179727"},"modified":"-0001-11-30T00:00:00","modified_gmt":"-0001-11-29T21:00:00","slug":"","status":"publish","type":"post","link":"https:\/\/savepearlharbor.com\/?p=179727","title":{"rendered":"<span class=\"post_title\">\u042f \u0437\u043d\u0430\u044e jQuery. \u0427\u0442\u043e \u0434\u0430\u043b\u044c\u0448\u0435?<\/span>"},"content":{"rendered":"<div class=\"content html_format\">\n<blockquote><p>\u041f\u0435\u0440\u0435\u0432\u043e\u0434 <a href=\"http:\/\/remysharp.com\/2013\/04\/19\/i-know-jquery-now-what\/\">\u0441\u0442\u0430\u0442\u044c\u0438<\/a> \u043e\u0442 <a href=\"http:\/\/remysharp.com\/about\/\">\u0420\u0435\u043c\u0438 \u0428\u0430\u0440\u043f (Remy Sharp)<\/a><br \/>  \u0414\u043b\u044f \u043b\u044e\u0431\u0438\u0442\u0435\u043b\u0435\u0439 \u043f\u0440\u043e\u043b\u0438\u0441\u0442\u044b\u0432\u0430\u0442\u044c \u0432 \u0441\u0430\u043c\u044b\u0439 \u043a\u043e\u043d\u0435\u0446 \u2014 \u0443\u0436\u0435 \u043d\u0430\u043a\u0440\u044b\u0442\u043e.<\/p><\/blockquote>\n<p>  \u042f \u0437\u0430\u0432\u0451\u043b \u044d\u0442\u043e\u0442 \u0440\u0430\u0437\u0433\u043e\u0432\u043e\u0440: &quot;<a href=\"https:\/\/speakerdeck.com\/rem\/i-know-jquery-now-what\">\u042f \u0437\u043d\u0430\u044e jQuery. \u0427\u0442\u043e \u0442\u0435\u043f\u0435\u0440\u044c?<\/a>&quot; \u043d\u0430 <b>jQuery UK 2013<\/b>, \u043d\u043e \u0432\u043c\u0435\u0441\u0442\u043e \u043c\u043e\u0435\u0433\u043e \u043e\u0431\u044b\u0447\u043d\u043e\u0433\u043e \u043f\u043e\u0434\u0445\u043e\u0434\u0430 \u043f\u043e\u0441\u0442-IT \u0432\u0437\u0440\u044b\u0432\u0430 \u043d\u0430 \u043c\u043e\u0435\u043c \u0441\u0442\u043e\u043b\u0435, \u044f \u043d\u0430\u043f\u0438\u0441\u0430\u043b \u0441\u043d\u0430\u0447\u0430\u043b\u0430 \u043f\u043e\u0441\u0442 \u0438 \u0441\u043e\u0437\u0434\u0430\u043b \u043f\u043e \u043d\u0435\u043c\u0443 \u0441\u043b\u0430\u0439\u0434\u044b. \u0422\u0430\u043a \u0432\u043e\u0442, \u043c\u043e\u0438 (\u0434\u043e\u0432\u043e\u043b\u044c\u043d\u043e \u043d\u0435\u043e\u0442\u0440\u0435\u0434\u0430\u043a\u0442\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u044b\u0435) \u043a\u0432\u0430\u0437\u0438-\u043f\u0440\u043e\u0433\u0443\u043b\u043a\u0438 \u043e \u0442\u043e\u043c, \u043a\u0430\u043a \u044f \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043b jQuery \u0438 \u043a\u0430\u043a \u044f \u0441\u043c\u043e\u0442\u0440\u044e \u043d\u0430 \u0442\u043e, \u0433\u0434\u0435 \u044f \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044e \u043d\u0430\u0442\u0438\u0432\u043d\u044b\u0435 \u0442\u0435\u0445\u043d\u043e\u043b\u043e\u0433\u0438\u0438 \u0431\u0440\u0430\u0443\u0437\u0435\u0440\u0430.<br \/>  <img decoding=\"async\" src=\"http:\/\/remysharp.com\/images\/i-know-jquery.jpg\" alt=\"I know jQuery. Now what?\"\/><br \/>  <a name=\"habracut\"><\/a>  <\/p>\n<h2>7 \u043b\u0435\u0442 \u043d\u0430\u0437\u0430\u0434\u2026<\/h2>\n<p>  17 \u0438\u044e\u043d\u044f 2006 \u0433\u043e\u0434\u0430 \u044f \u043e\u043f\u0443\u0431\u043b\u0438\u043a\u043e\u0432\u0430\u043b \u043c\u043e\u0439 \u0441\u0430\u043c\u044b\u0439 \u043f\u0435\u0440\u0432\u044b\u0439 <a href=\"http:\/\/web.archive.org\/web\/20061018170852\/http:\/\/leftlogic.com\/info\/articles\/auto-selecting_navigation\">\u043f\u043e\u0441\u0442<\/a> \u0432 \u0431\u043b\u043e\u0433\u0435: \u0440\u0435\u0433\u0443\u043b\u044f\u0440\u043d\u044b\u0439 \u043f\u0440\u0438\u0451\u043c JavaScript \u0438 \u0443\u043f\u0440\u043e\u0449\u0435\u043d\u0438\u0435 \u0434\u043b\u044f \u0441\u0438\u043d\u0442\u0430\u043a\u0441\u0438\u0441\u0430 jQuery. \u041e\u043d \u0441\u043e\u043a\u0440\u0430\u0449\u0430\u043b 14 \u0441\u0442\u0440\u043e\u043a JavaScript \u0434\u043e 3 \u0441\u0442\u0440\u043e\u043a jQuery (\u0434\u043e jQuery 1.0).<\/p>\n<p>  \u0421\u0430\u043c\u043e\u0435 \u0433\u043b\u0430\u0432\u043d\u043e\u0435, \u0447\u0442\u043e \u044d\u0442\u043e \u043f\u043e\u0448\u043b\u043e \u043e\u0442 \u043d\u0435\u043a\u043e\u0439 \u043d\u0435\u0443\u0434\u043e\u0431\u043d\u043e\u0439 DOM \u043d\u0430\u0432\u0438\u0433\u0430\u0446\u0438\u0438 \u043a \u043f\u0440\u043e\u0441\u0442\u043e\u043c\u0443 CSS \u0432\u044b\u0440\u0430\u0436\u0435\u043d\u0438\u044e \u0438 \u0434\u043e\u0431\u0430\u0432\u043b\u044f\u043b\u043e \u043a\u043b\u0430\u0441\u0441 \u043f\u043e \u0437\u0430\u0432\u0435\u0440\u0448\u0435\u043d\u0438\u044e. \u041e\u0440\u0438\u0433\u0438\u043d\u0430\u043b\u044c\u043d\u044b\u0439 JavaScript \u0431\u044b\u043b \u0442\u0430\u043a\u0436\u0435 \u0434\u043e\u0432\u043e\u043b\u044c\u043d\u043e \u0445\u0440\u0443\u043f\u043a\u0438\u043c, \u043f\u043e\u044d\u0442\u043e\u043c\u0443 \u044d\u0442\u043e \u043e\u0437\u043d\u0430\u0447\u0430\u043b\u043e, \u0447\u0442\u043e \u0443 \u0412\u0430\u0441 \u0442\u0430\u043a \u0438\u043b\u0438 \u0438\u043d\u0430\u0447\u0435 \u0431\u044b\u043b\u0430 \u0442\u0430 \u0436\u0435 \u0440\u0430\u0437\u043c\u0435\u0442\u043a\u0430.<\/p>\n<p>  \u042f \u043f\u0440\u0435\u0434\u0441\u0442\u0430\u0432\u0438\u043b jQuery \u043a\u043e\u043c\u0430\u043d\u0434\u0435 \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a\u043e\u0432, \u0441 \u043a\u043e\u0442\u043e\u0440\u044b\u043c\u0438 \u044f \u0440\u0430\u0431\u043e\u0442\u0430\u043b \u0435\u0449\u0435 \u0441 \u0441\u0435\u0440\u0435\u0434\u0438\u043d\u044b 2000-\u0445 \u0433\u043e\u0434\u043e\u0432, \u0438 \u0434\u0430\u0436\u0435 \u0434\u0438\u0437\u0430\u0439\u043d\u0435\u0440\u043e\u0432 \u043e\u043d \u043f\u0440\u0438\u0432\u043b\u0451\u043a (\u0442\u0430\u043a \u043a\u0430\u043a \u043e\u043d\u0438 \u043e\u0431\u044b\u0447\u043d\u043e \u043f\u043e\u043d\u0438\u043c\u0430\u044e\u0442 CSS \u0441\u0435\u043b\u0435\u043a\u0442\u043e\u0440\u044b (\u0438 \u0441 \u0442\u0435\u0445 \u043f\u043e\u0440 jQuery \u0440\u043e\u0434\u0438\u043b\u0441\u044f \u0434\u043b\u044f \u0434\u0438\u0437\u0430\u0439\u043d\u0435\u0440\u043e\u0432)).<\/p>\n<h2>DOM \u043d\u0430\u0432\u0438\u0433\u0430\u0446\u0438\u0438 \u0432\u0434\u0440\u0443\u0433 \u043f\u043e\u043b\u0435\u0433\u0447\u0430\u043b\u043e<\/h2>\n<p>  \u0422\u043e\u0433\u0434\u0430 DOM \u0431\u044b\u043b\u043e \u0442\u0440\u0443\u0434\u043d\u043e \u043e\u0440\u0438\u0435\u043d\u0442\u0438\u0440\u043e\u0432\u0430\u0442\u044c\u0441\u044f. \u0412\u044b \u043c\u043e\u0433\u043b\u0438 \u0431\u044b\u0442\u044c \u0443\u0432\u0435\u0440\u0435\u043d\u044b, \u0447\u0442\u043e, \u0435\u0441\u043b\u0438 \u043e\u043d \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u0432 Firefox 1.5, \u043e\u043d \u043d\u0435 \u0431\u0443\u0434\u0435\u0442 \u0440\u0430\u0431\u043e\u0442\u0430\u0442\u044c \u0432 IE6.<\/p>\n<p>  \u041f\u0440\u043e\u0441\u0442\u043e\u0442\u0430, \u0441 \u043a\u043e\u0442\u043e\u0440\u043e\u0439 \u043c\u043e\u0436\u043d\u043e \u0431\u044b\u043b\u043e \u0431\u044b \u043f\u043e\u0437\u043d\u0430\u0442\u044c jQuery, \u043f\u0440\u0438\u0432\u043b\u0435\u043a\u0430\u043b\u0430 \u043c\u0435\u043d\u044f. \u0412\u0441\u044f DOM \u043d\u0430\u0432\u0438\u0433\u0430\u0446\u0438\u044f \u0431\u044b\u043b\u0430 \u0441\u0434\u0435\u043b\u0430\u043d\u0430 \u0441 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u0435\u043c CSS \u0432\u044b\u0440\u0430\u0436\u0435\u043d\u0438\u044f, \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044f \u043d\u0435\u043a\u0443\u044e \u0431\u0435\u0437\u0443\u043c\u043d\u0443\u044e \u043a\u043e\u0440\u043e\u0431\u043a\u0443 \u0447\u0451\u0440\u043d\u043e\u0439 \u043c\u0430\u0433\u0438\u0438, \u0442\u0443, \u0447\u0442\u043e \u043f\u0440\u0438\u0434\u0443\u043c\u0430\u043b \u0414\u0436\u043e\u043d \u0420\u0435\u0437\u0438\u0433 \u2014 \u0441\u043f\u0430\u0441\u0435\u043d\u0438\u0435 \u043c\u043e\u0435\u0439 \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u043d\u043e\u0439 \u043c\u043e\u0449\u043d\u043e\u0441\u0442\u0438 \u043c\u043e\u0437\u0433\u0430, \u0438 \u043a\u0430\u043a \u0442\u043e\u043b\u044c\u043a\u043e \u0443 \u043c\u0435\u043d\u044f \u0431\u044b\u043b\u0438 \u0442\u0435 \u0443\u0437\u043b\u044b (nodes) DOM, \u044f \u043c\u043e\u0433 \u0434\u0435\u043b\u0430\u0442\u044c \u0441 \u043d\u0438\u043c\u0438 \u0442\u043e, \u0447\u0442\u043e \u0445\u043e\u0442\u0435\u043b (\u043e\u0431\u044b\u0447\u043d\u043e \u044d\u0442\u043e \u043a\u043e\u043c\u0431\u0438\u043d\u0430\u0446\u0438\u0438 \u043e\u0442\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u044f, \u0441\u043a\u0440\u044b\u0442\u0438\u044f, \u0438\u0441\u0447\u0435\u0437\u0430\u043d\u0438\u044f \u0438 \u0442.\u0434.).<\/p>\n<h2>\u041f\u043e\u043d\u0438\u043c\u0430\u043d\u0438\u0435 ajax<\/h2>\n<p>  <img decoding=\"async\" src=\"https:\/\/speakerd.s3.amazonaws.com\/presentations\/aecd8ed08ac00130a95d22000a1e8d60\/slide_6.jpg\" alt=\"ajax\"\/><\/p>\n<p>  jQuery \u0432\u044b\u0434\u0435\u043b\u0438\u043b \u0434\u043b\u044f \u043c\u0435\u043d\u044f \u0442\u0430\u043a\u0443\u044e \u0432\u0435\u0449\u044c \u043a\u0430\u043a ajax. \u0422\u0435\u0440\u043c\u0438\u043d \u0432\u0432\u0435\u043b\u0438 \u043d\u0435\u043c\u043d\u043e\u0433\u0438\u043c \u0440\u0430\u043d\u0435\u0435 \u0432 2005, \u043d\u043e \u0434\u043e\u043a\u0443\u043c\u0435\u043d\u0442\u0430\u0446\u0438\u044f \u043d\u0435 \u0431\u044b\u043b\u0430 \u0448\u0438\u0440\u043e\u043a\u043e\u0439, \u043d\u0438 \u043d\u0435\u0437\u043d\u0430\u0447\u0438\u0442\u0435\u043b\u044c\u043d\u043e\u0439, \u043e\u0431\u044b\u0447\u043d\u043e\u0439 \u043a \u043f\u043e\u043d\u0438\u043c\u0430\u043d\u0438\u044e (\u043d\u0435 \u0437\u0430\u0431\u044b\u0432\u0430\u0439\u0442\u0435 \u043e \u0431\u043e\u043b\u0435\u0435 \u043d\u0438\u0437\u043a\u043e\u0439 \u0432\u044b\u0447\u0438\u0441\u043b\u0438\u0442\u0435\u043b\u044c\u043d\u043e\u0439 \u043c\u043e\u0449\u043d\u043e\u0441\u0442\u0438 \u043c\u043e\u0435\u0433\u043e \u043c\u043e\u0437\u0433\u0430).<\/p>\n<p>  \u042d\u0442\u043e \u0431\u044b\u043b \u043f\u0435\u0440\u0432\u044b\u0439 \u0440\u0430\u0437, \u043a\u043e\u0433\u0434\u0430 \u043c\u043d\u0435 \u0440\u0435\u0430\u043b\u044c\u043d\u043e \u043d\u0443\u0436\u043d\u043e \u0431\u044b\u043b\u043e \u0438\u043c\u0435\u0442\u044c \u0434\u0435\u043b\u043e \u0441 \u043e\u0431\u044a\u0435\u043a\u0442\u043e\u043c <b>XMLHttpRequest<\/b>, \u0438 \u0432\u0438\u0434\u044f \u0435\u0433\u043e \u0432\u043f\u0435\u0440\u0432\u044b\u0435, \u043f\u043e\u043d\u0438\u043c\u0430\u043d\u0438\u0435 \u0441\u043e\u0431\u044b\u0442\u0438\u044f <b>onreadystatechange<\/b> \u0438 \u043a\u043e\u043c\u0431\u0438\u043d\u0430\u0446\u0438\u0438: <b>this.status<\/b> \u0438 <b>this.readyState<\/b> \u043d\u0435 \u0431\u044b\u043b\u043e \u043e\u0442\u043a\u0440\u044b\u0442\u043e \u044f\u0441\u043d\u044b\u043c! jQuery (\u0438 \u0434\u0440\u0443\u0433\u0438\u0435 \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0438) \u0442\u0430\u043a\u0436\u0435 \u0443\u0431\u0440\u0430\u043b \u0431\u0435\u0441\u043f\u043e\u0440\u044f\u0434\u043e\u043a, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0431\u044b\u043b \u0441 XHR \u0432 IE \u0447\u0435\u0440\u0435\u0437 ActiveX \u2026  <\/p>\n<pre><code class=\"javascript\">function getXmlHttpRequest() { \tvar xhr; \tif (window.XMLHttpRequest) { \t\txhr = new XMLHttpRequest(); \t} else { \t\ttry { \t\t\txhr = new ActiveXObject(&quot;Msxml2.XMLHTTP&quot;); \t\t} catch (e) { \t\t\ttry { \t\t\t\txhr = new ActiveXObject(&quot;Microsoft.XMLHTTP&quot;); \t\t\t} catch (e) { \t\t\t\txhr = false; \t\t\t} \t\t} \t} \treturn xhr; }  \/\/ \u043f\u0440\u0438\u043c\u0435\u0447\u0430\u043d\u0438\u0435: jQuery \u0432\u0435\u0440\u0441\u0438\u044f \u0414\u0436\u043e\u043d\u0430 \u0433\u043e\u0440\u0430\u0437\u0434\u043e \u044d\u043b\u0435\u0433\u0430\u043d\u0442\u043d\u0435\u0439! <\/code><\/pre>\n<p>  \u041a\u0430\u043a \u0442\u043e\u043b\u044c\u043a\u043e \u044f \u0443\u0432\u0438\u0434\u0435\u043b \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u0435 \u0443\u0442\u0438\u043b\u0438\u0442\u044b ajax \u0432\u043d\u0443\u0442\u0440\u0438 jQuery, \u0447\u0442\u043e\u0431\u044b \u043f\u043e\u0433\u043b\u043e\u0449\u0430\u0442\u044c URL HTML (\u043e\u0431\u044b\u0447\u043d\u044b\u0439 \u0441\u043f\u043e\u0441\u043e\u0431, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u043c\u044b \u0445\u043e\u0442\u0435\u043b\u0438, \u0447\u0442\u043e\u0431\u044b \u0441\u0434\u0435\u043b\u0430\u0442\u044c ajax), \u0442\u043e ajax \u0432\u0434\u0440\u0443\u0433 \u0449\u0451\u043b\u043a\u043d\u0443\u043b.<\/p>\n<p>  jQuery \u0431\u044b\u0441\u0442\u0440\u043e \u0441\u0442\u0430\u043b \u043c\u043e\u0435\u0439 \u0441\u0442\u0430\u043d\u0434\u0430\u0440\u0442\u043d\u043e\u0439 \u0443\u0442\u0438\u043b\u0438\u0442\u043e\u0439 \u0432 \u0442\u0435\u0447\u0435\u043d\u0438\u0435 \u043c\u043d\u043e\u0433\u0438\u0445 \u043b\u0435\u0442. \u042d\u0442\u043e \u0431\u044b\u043b \u043c\u043e\u0439 \u0448\u0432\u0435\u0439\u0446\u0430\u0440\u0441\u043a\u0438\u0439 \u0430\u0440\u043c\u0435\u0439\u0441\u043a\u0438\u0439 \u043d\u043e\u0436, \u0442\u0430\u043a \u0441\u043a\u0430\u0437\u0430\u0442\u044c, \u043d\u0430\u0437\u0432\u0430\u043d\u0438\u0435 \u0443\u043a\u0440\u0430\u043b \u0438\u0437 <a href=\"http:\/\/events.jquery.org\/2013\/uk\/schedule.html#adam\">\u0437\u0430\u0433\u043e\u043b\u043e\u0432\u043a\u0430 \u0440\u0430\u0437\u0433\u043e\u0432\u043e\u0440\u0430 \u0410\u0434\u0430\u043c\u0430<\/a>!<\/p>\n<h2>\u041d\u0430\u0437\u0430\u0434 \u0432 \u0431\u0443\u0434\u0443\u0449\u0435\u0435: \u0441\u0435\u0433\u043e\u0434\u043d\u044f<\/h2>\n<p>  <img decoding=\"async\" src=\"https:\/\/speakerd.s3.amazonaws.com\/presentations\/aecd8ed08ac00130a95d22000a1e8d60\/slide_8.jpg\" alt=\"\u041d\u0430\u0437\u0430\u0434 \u0432 \u0431\u0443\u0434\u0443\u0449\u0435\u0435\"\/><\/p>\n<p>  \u0414\u0430\u0432\u0430\u0439\u0442\u0435 \u043f\u0435\u0440\u0435\u043c\u0430\u0442\u0430\u0435\u043c \u043d\u0430\u0437\u0430\u0434 \u0434\u043e \u0441\u0435\u0433\u043e\u0434\u043d\u044f\u0448\u043d\u0435\u0433\u043e \u0434\u043d\u044f. \u0427\u0442\u043e \u043f\u0440\u043e\u0438\u0437\u043e\u0448\u043b\u043e \u0437\u0430 \u044d\u0442\u0438 \u0433\u043e\u0434\u044b?<\/p>\n<p>  \u0414\u043b\u044f \u043d\u043e\u0432\u0438\u0447\u043a\u043e\u0432, \u043f\u043e \u0443\u043c\u043e\u043b\u0447\u0430\u043d\u0438\u044e \u043c\u043e\u044f \u043d\u0430\u0447\u0430\u043b\u044c\u043d\u0430\u044f \u043f\u043e\u0437\u0438\u0446\u0438\u044f \u043d\u0435 \u0431\u043e\u043b\u0435\u0435, \u0447\u0435\u043c \u00ab\u0432\u043a\u043b\u044e\u0447\u0438\u0442\u044c jQuery \u043f\u043e \u0443\u043c\u043e\u043b\u0447\u0430\u043d\u0438\u044e\u00bb. \u042f \u0431\u043e\u043b\u044c\u0448\u0435 \u043f\u043e\u043d\u0438\u043c\u0430\u044e JavaScript \u0438 \u043a\u0430\u043a \u043e\u043d \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442.<\/p>\n<p>  \u0423 \u043c\u0435\u043d\u044f \u0435\u0441\u0442\u044c \u0441\u0432\u043e\u0438 \u043a\u0440\u0438\u0442\u0435\u0440\u0438\u0438, \u043a\u043e\u0433\u0434\u0430 \u0432\u043a\u043b\u044e\u0447\u0430\u0442\u044c jQuery \u0438 \u043a\u043e\u0433\u0434\u0430 \u043d\u0435 \u0432\u043a\u043b\u044e\u0447\u0430\u0442\u044c jQuery. \u041d\u043e \u0435\u0441\u043b\u0438 \u044f \u043d\u0435 \u0432\u043a\u043b\u044e\u0447\u0430\u044e jQuery, \u0442\u043e \u0447\u0442\u043e?<\/p>\n<p>  \u0417\u0430 \u0442\u0435 7 \u043b\u0435\u0442 \u0441\u043e\u0432\u0441\u0435\u043c \u043c\u0430\u043b\u043e \u0447\u0442\u043e \u0438\u0437\u043c\u0435\u043d\u0438\u043b\u043e\u0441\u044c. \u0412\u0435\u0440\u043e\u044f\u0442\u043d\u043e, \u043e\u0434\u043d\u0438\u043c \u0438\u0437 \u0441\u0430\u043c\u044b\u0445 \u0432\u0430\u0436\u043d\u044b\u0445 \u0448\u0430\u0433\u043e\u0432 \u0441\u0442\u0430\u043b\u043e \u0432\u0432\u0435\u0434\u0435\u043d\u0438\u0435 <b>querySelectorAll<\/b>.<\/p>\n<p>  \u0411\u0443\u0434\u0443\u0447\u0438 \u043f\u043e\u0437\u0432\u043e\u043b\u0438\u0432 \u0434\u0430\u0442\u044c \u043d\u0430\u0442\u0438\u0432\u043d\u043e\u0439 \u0444\u0443\u043d\u043a\u0446\u0438\u0438 \u0431\u0440\u0430\u0443\u0437\u0435\u0440\u0430 \u0432\u044b\u0440\u0430\u0436\u0435\u043d\u0438\u044f CSS \u0438 \u043e\u043d\u0430 \u0441\u0434\u0435\u043b\u0430\u0435\u0442 \u0440\u0430\u0431\u043e\u0442\u0443 \u043d\u0430\u0432\u0438\u0433\u0430\u0446\u0438\u0438 \u043f\u043e DOM \u2014 \u043e\u0433\u0440\u043e\u043c\u043d\u0443\u044e (\u0432 \u0431\u0443\u043a\u0432\u0430\u043b\u044c\u043d\u043e\u043c \u0441\u043c\u044b\u0441\u043b\u0435) \u0447\u0430\u0441\u0442\u044c jQuery. \u0411\u0430\u0437\u043e\u0432\u0430\u044f \u043f\u043e\u0434\u0434\u0435\u0440\u0436\u043a\u0430 \u0431\u044b\u043b\u0430 \u0432 Chrome \u0441 \u0441\u0430\u043c\u043e\u0433\u043e \u043d\u0430\u0447\u0430\u043b\u0430, \u0430 \u0432 IE8 \u0438 Firefox 3.5 \u043f\u0440\u0438\u043c\u0435\u0440\u043d\u043e \u0432 \u0441\u0435\u0440\u0435\u0434\u0438\u043d\u0435 2009 \u0433\u043e\u0434\u0430.<\/p>\n<p>  \u0423 \u042d\u043d\u0434\u0440\u044e \u041b\u0443\u043d\u043d\u0438 (\u0438\u0437 PhoneGap \u0438 Adobe) \u0435\u0441\u0442\u044c \u0441\u0432\u0435\u0440\u043a\u0430\u044e\u0449\u0430\u044f \u043f\u0440\u043e\u0441\u0442\u043e\u0442\u0430 \u0432 \u0431\u043b\u0435\u0441\u0442\u044f\u0449\u0435\u0439 \u0444\u0443\u043d\u043a\u0446\u0438\u0438:  <\/p>\n<pre><code class=\"javascript\">var $ = document.querySelectorAll.bind(document); Element.prototype.on = Element.prototype.addEventListener;  $('#somelink')[0].on('touchstart', handleTouch); <\/code><\/pre>\n<p>  \u041f\u043e\u0442\u0440\u044f\u0441\u0430\u044e\u0449\u0435 \u043f\u0440\u043e\u0441\u0442\u043e.<\/p>\n<p>  \u042f \u0440\u0430\u0437\u0432\u0438\u043b \u044d\u0442\u0443 \u0438\u0434\u0435\u044e \u043d\u0435\u043c\u043d\u043e\u0433\u043e <a href=\"https:\/\/github.com\/remy\/min.js\">\u0434\u0430\u043b\u044c\u0448\u0435<\/a> \u0438 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043b \u0435\u0451 \u043d\u0430 \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u0438\u0445 \u0441\u043f\u0435\u0446\u0438\u0444\u0438\u0447\u043d\u044b\u0445 \u043f\u0440\u043e\u0435\u043a\u0442\u0430\u0445, \u0434\u043e\u0431\u0430\u0432\u0438\u0432 \u043f\u043e\u0434\u0434\u0435\u0440\u0436\u043a\u0443 \u0441\u0446\u0435\u043f\u043b\u0435\u043d\u0438\u044f, \u0446\u0438\u043a\u043b\u043e\u0432 \u0438 \u0443\u043f\u0440\u043e\u0449\u0435\u043d\u0438\u0435 \u0441\u0438\u043d\u0442\u0430\u043a\u0441\u0438\u0441\u0430. \u041d\u0430 \u0432\u044b\u0445\u043e\u0434\u0435 \u0447\u0443\u0442\u044c \u043c\u0435\u043d\u044c\u0448\u0435 200 \u0431\u0430\u0439\u0442\u043e\u0432 \u0441 gzip \u0441\u0436\u0430\u0442\u0438\u0435\u043c. \u041d\u043e \u0434\u0435\u043b\u043e \u0432 \u0442\u043e\u043c, \u0447\u0442\u043e \u0441\u0435\u0433\u043e\u0434\u043d\u044f \u043d\u0430\u043c \u0434\u043e\u0441\u0442\u0443\u043f\u043d\u044b \u043d\u0430\u0442\u0438\u0432\u043d\u044b\u0435 \u0444\u0443\u043d\u043a\u0446\u0438\u0438, \u0438 \u044f \u043f\u044b\u0442\u0430\u044e\u0441\u044c \u0440\u0430\u0441\u0441\u043c\u043e\u0442\u0440\u0435\u0442\u044c \u043c\u043e\u044e \u0430\u0443\u0434\u0438\u0442\u043e\u0440\u0438\u044e, \u043f\u0440\u0435\u0436\u0434\u0435 \u0447\u0435\u043c \u043f\u043e\u0434\u043a\u043b\u044e\u0447\u0430\u0442\u044c jQuery \u043f\u043e \u0443\u043c\u043e\u043b\u0447\u0430\u043d\u0438\u044e.<\/p>\n<h2>\u041a\u043e\u0433\u0434\u0430 \u044f \u043e\u0431\u044b\u0447\u043d\u043e \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044e jQuery<\/h2>\n<p>  \u041f\u0440\u0435\u0436\u0434\u0435, \u0447\u0435\u043c \u044f \u043f\u043e\u0441\u043c\u043e\u0442\u0440\u044e \u043d\u0430 \u0442\u043e, \u043a\u0430\u043a \u044f \u043c\u043e\u0433\u0443 \u043e\u0431\u043e\u0439\u0442\u0438\u0441\u044c \u0431\u0435\u0437 jQuery, \u043f\u043e\u0437\u0432\u043e\u043b\u044c\u0442\u0435 \u043c\u043d\u0435 \u043f\u043e\u0434\u0435\u043b\u0438\u0442\u044c\u0441\u044f, \u043a\u043e\u0433\u0434\u0430 \u044f \u043f\u043e\u0434\u043a\u043b\u044e\u0447\u0430\u044e jQuery \u043a \u043f\u0440\u043e\u0435\u043a\u0442\u0443. \u041e\u0431\u044b\u0447\u043d\u043e \u044d\u0442\u043e \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u0432\u0435\u0441\u044c\u043c\u0430 \u0441\u043f\u0435\u0446\u0438\u0444\u0438\u0447\u043d\u044b\u0445 \u043a\u0440\u0438\u0442\u0435\u0440\u0438\u0435\u0432, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043b\u0438\u0431\u043e \u043e\u0431\u044f\u0437\u044b\u0432\u0430\u044e\u0442 \u043c\u0435\u043d\u044f \u043d\u0430\u0447\u0438\u043d\u0430\u0442\u044c \u0441 jQuery \u0438\u043b\u0438 \u043f\u0435\u0440\u0435\u043a\u043b\u044e\u0447\u0438\u0442\u044c\u0441\u044f \u0441 \u043f\u043e\u043c\u043e\u0449\u044c\u044e \u0437\u0430\u043a\u0430\u0437\u043d\u043e\u0433\u043e \u0440\u0435\u0448\u0435\u043d\u0438\u044f \u0432 \u043f\u043e\u043b\u044c\u0437\u0443 jQuery.<\/p>\n<p>  \u041f\u0440\u0435\u0436\u0434\u0435 \u0447\u0435\u043c \u044f \u0447\u0442\u043e-\u0442\u043e \u0434\u0435\u043b\u0430\u044e, \u043c\u043d\u0435 \u0441\u043b\u0435\u0434\u0443\u0435\u0442 \u043e\u0442\u043c\u0435\u0442\u0438\u0442\u044c, \u043a\u043e\u0433\u0434\u0430 \u044f \u0430\u0431\u0441\u043e\u043b\u044e\u0442\u043d\u043e \u043d\u0435 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044e jQuery: \u0435\u0441\u043b\u0438 \u044f \u043f\u044b\u0442\u0430\u044e\u0441\u044c \u043f\u043e\u0432\u0442\u043e\u0440\u0438\u0442\u044c \u043e\u0448\u0438\u0431\u043a\u0443 \u0431\u0440\u0430\u0443\u0437\u0435\u0440\u0430, \u044f \u043d\u0438\u043a\u043e\u0433\u0434\u0430 \u043d\u0435 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044e \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0443. \u0415\u0441\u043b\u0438 \u0412\u044b \u043f\u044b\u0442\u0430\u0435\u0442\u0435\u0441\u044c \u0437\u0430\u0433\u043d\u0430\u0442\u044c \u043e\u0448\u0438\u0431\u043a\u0443 \u0432 \u0443\u0433\u043e\u043b, \u0447\u0442\u043e\u0431\u044b \u0412\u044b \u043c\u043e\u0433\u043b\u0438 \u043e\u043f\u0440\u0435\u0434\u0435\u043b\u0438\u0442\u044c \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u0443, \u0412\u0430\u043c \u043d\u0443\u0436\u043d\u043e, \u0447\u0442\u043e\u0431\u044b \u0412\u0430\u0448 \u0441\u043b\u0443\u0447\u0430\u0439 \u0431\u044b\u043b \u043c\u0438\u043d\u0438\u043c\u0430\u043b\u044c\u043d\u043e \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u044b\u043c (\u0435\u0441\u043b\u0438, \u043a\u043e\u043d\u0435\u0447\u043d\u043e, \u0412\u044b \u043d\u0435 \u043e\u0431\u043d\u0430\u0440\u0443\u0436\u0438\u0432\u0430\u0435\u0442\u0435 \u043e\u0448\u0438\u0431\u043a\u0443 \u0432 jQuery!).<\/p>\n<h3>1. \u041a\u043e\u0433\u0434\u0430 \u043f\u0440\u043e\u0435\u043a\u0442 \u0434\u043e\u043b\u0436\u0435\u043d \u0440\u0430\u0431\u043e\u0442\u0430\u0442\u044c \u0432 \u043d\u0435-\u0434\u043e\u0431\u0438\u0432\u0448\u0438\u0445\u0441\u044f-\u0443\u043f\u0435\u0445\u0430 \u0431\u0440\u0430\u0443\u0437\u0435\u0440\u0430\u0445<\/h3>\n<p>  BBC \u0431\u044b\u043b\u0438 \u0432\u0435\u0441\u044c\u043c\u0430 \u0448\u0443\u043c\u043d\u044b\u043c\u0438 \u0432 \u0442\u043e\u043c, \u0447\u0442\u043e \u043e\u043d\u0438 \u043e\u043f\u0440\u0435\u0434\u0435\u043b\u044f\u043b\u0438 \u043f\u043e\u0434 &quot;<a href=\"http:\/\/blog.responsivenews.co.uk\/post\/18948466399\/cutting-the-mustard\/\">\u0434\u043e\u0431\u0438\u0432\u0448\u0438\u0439\u0441\u044f \u0443\u0441\u043f\u0435\u0445\u0430<\/a>&quot; (\u043f\u0440\u0438\u043c\u0435\u0447\u0430\u043d\u0438\u0435: \u0441\u0441\u044b\u043b\u043a\u0430 \u0440\u0430\u0431\u043e\u0442\u0430\u043b\u0430 \u0434\u043e 08.05.2013, <a href=\"http:\/\/webcache.googleusercontent.com\/search?q=cache:http:\/\/responsivenews.co.uk\/post\/18948466399\/cutting-the-mustard\">\u043a\u044d\u0448 \u0433\u0443\u0433\u043b\u0430<\/a> \u0432 \u043f\u043e\u043c\u043e\u0449\u044c), \u0438 \u0442\u0435\u043f\u0435\u0440\u044c \u044f \u0434\u0443\u043c\u0430\u044e \u043e\u0431 \u044d\u0442\u043e\u043c, \u044d\u0442\u043e \u043c\u043e\u0439 \u043e\u0440\u0438\u0435\u043d\u0442\u0438\u0440, \u043a\u043e\u0433\u0434\u0430 \u043f\u043e\u0434\u043a\u043b\u044e\u0447\u0430\u0442\u044c jQuery \u043f\u043e \u0443\u043c\u043e\u043b\u0447\u0430\u043d\u0438\u044e.<\/p>\n<p>  \u0415\u0441\u043b\u0438 \u044f \u0437\u043d\u0430\u044e, \u0447\u0442\u043e \u044f \u0434\u043e\u043b\u0436\u0435\u043d \u0440\u0430\u0431\u043e\u0442\u0430\u0442\u044c \u0441 \u0431\u0440\u0430\u0443\u0437\u0435\u0440\u0430\u043c\u0438, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043d\u0435 \u0434\u043e\u0431\u0438\u043b\u0438\u0441\u044c \u0443\u0441\u043f\u0435\u0445\u0430, \u0438 \u043e\u043d\u0438 \u044f\u0432\u043b\u044f\u044e\u0442\u0441\u044f \u0447\u0430\u0441\u0442\u044c\u044e \u043e\u0441\u043d\u043e\u0432\u043d\u043e\u0439 \u0430\u0443\u0434\u0438\u0442\u043e\u0440\u0438\u0438, \u0442\u043e \u044f \u043d\u0430\u0447\u043d\u0443 \u0441 jQuery \u0432 \u043c\u043e\u0435\u043c \u043f\u0435\u0440\u0432\u043e\u043d\u0430\u0447\u0430\u043b\u044c\u043d\u043e\u043c \u043a\u043e\u0434\u0435.<\/p>\n<p>  \u0427\u0442\u043e \u0437\u043d\u0430\u0447\u0438\u0442 <abbr title=\"\u0410\u043d\u0433\u043b.: cutting the mustard\">\u0434\u043e\u0431\u0438\u0442\u044c\u0441\u044f \u0443\u0441\u043f\u0435\u0445\u0430<\/abbr>?<\/p>\n<p>  \u042d\u0442\u043e \u043f\u043e\u0447\u0442\u0438 \u0442\u0430\u043a\u0436\u0435 \u043f\u0440\u043e\u0441\u0442\u043e, \u043a\u0430\u043a: \u0415\u0441\u0442\u044c \u043b\u0438 \u0432 \u0431\u0440\u0430\u0443\u0437\u0435\u0440\u0435 <b>querySelectorAll<\/b>?<\/p>\n<p>  BBC \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442 \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0438\u0439 \u0442\u0435\u0441\u0442 \u0434\u043b\u044f \u0434\u043e\u0441\u0442\u0438\u0436\u0435\u043d\u0438\u044f \u0443\u0441\u043f\u0435\u0445\u0430:  <\/p>\n<pre><code class=\"javascript\">if ('querySelector' in document &&  \t'localStorage' in window &&  \t'addEventListener' in window) { \t\/\/ \u0432\u0430\u0448\u0435 JavaScript \u043f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u0435 } <\/code><\/pre>\n<p>  \u041f\u0435\u0440\u0432\u043e\u0435, \u0447\u0442\u043e \u043c\u043d\u0435 \u043f\u0440\u0438\u0448\u043b\u043e \u0432 \u0433\u043e\u043b\u043e\u0432\u0443, IE8 \u043d\u0435 \u043f\u043e\u0434\u0434\u0435\u0440\u0436\u0438\u0432\u0430\u0435\u0442 <b>addEventListener<\/b> (\u043d\u043e \u0435\u0441\u0442\u044c <a href=\"https:\/\/gist.github.com\/eirikbacker\/2864711\">polyfill<\/a>), \u0442\u0430\u043a \u0447\u0442\u043e \u0435\u0441\u043b\u0438 \u044d\u0442\u043e \u0432\u0430\u0436\u043d\u044b\u0439 \u0431\u0440\u0430\u0443\u0437\u0435\u0440 \u0434\u043b\u044f \u043f\u0440\u043e\u0435\u043a\u0442\u0430, \u0442\u043e \u044f \u0437\u043d\u0430\u044e, \u0447\u0442\u043e \u044f \u043d\u0435 \u0445\u043e\u0447\u0443 \u043d\u0430\u0447\u0438\u043d\u0430\u0442\u044c \u043f\u0440\u043e\u0435\u043a\u0442, \u043f\u0440\u044b\u0433\u0430\u044f \u0447\u0435\u0440\u0435\u0437 \u043e\u0431\u0440\u0443\u0447 \u0440\u0430\u0434\u0438 IE8.<\/p>\n<p>  \u042d\u0442\u043e \u043d\u0435 \u0437\u043d\u0430\u0447\u0438\u0442, \u0447\u0442\u043e\u0431\u044b \u0433\u043e\u0432\u043e\u0440\u0438\u0442\u044c \u043e \u0442\u043e\u043c, \u0447\u0442\u043e \u0442\u0435 \u043f\u0440\u043e\u0435\u043a\u0442\u044b, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u044f \u043d\u0430\u0447\u0438\u043d\u0430\u044e \u0431\u0435\u0437 jQuery \u043d\u0435 \u0431\u0443\u0434\u0443\u0442 \u043f\u043e\u0434\u0434\u0435\u0440\u0436\u0438\u0432\u0430\u0442\u044c IE8, \u044d\u0442\u043e \u0431\u043e\u043b\u044c\u0448\u0435\u0435, \u0447\u0435\u043c \u0412\u044b \u0445\u043e\u0442\u0435\u043b\u0438 \u0431\u044b \u043d\u0430\u0447\u0430\u0442\u044c \u0441 \u043f\u0440\u043e\u0441\u0442\u043e\u0433\u043e, \u0438 \u0434\u0435\u0440\u0436\u0430\u0442\u044c \u0440\u0430\u0437\u0432\u0438\u0442\u0438\u0435 \u043f\u0440\u043e\u0441\u0442\u044b\u0445 \u0441 \u0441\u0430\u043c\u043e\u0433\u043e \u043d\u0430\u0447\u0430\u043b\u0430. \u0415\u0441\u043b\u0438 \u044f \u043d\u0430\u0447\u0438\u043d\u0430\u044e \u043f\u0440\u043e\u0435\u043a\u0442 \u0441 \u043c\u0435\u0448\u043a\u043e\u043c \u0445\u0430\u043a\u043e\u0432 \u2014 \u044f \u0437\u043d\u0430\u044e, \u0447\u0442\u043e \u0431\u0443\u0434\u0435\u0442 \u0441\u0442\u044b\u0447\u043a\u0430.<\/p>\n<p>  \u042f \u0442\u0430\u043a\u0436\u0435 \u043a\u043b\u0430\u0441\u0441\u0438\u0444\u0438\u0446\u0438\u0440\u043e\u0432\u0430\u043b \u0431\u044b \u044d\u0442\u043e \u043a\u0430\u043a \u00ab\u043a\u043e\u0433\u0434\u0430 \u0441\u043b\u043e\u0436\u043d\u043e\u0441\u0442\u044c \u043f\u0435\u0440\u0435\u0432\u0435\u0448\u0438\u0432\u0430\u0435\u0442 \u043b\u0451\u0433\u043a\u043e\u0441\u0442\u044c\u00bb.<\/p>\n<h3>2. \u041a\u043e\u0433\u0434\u0430 \u044d\u0442\u043e \u0431\u044b\u0441\u0442\u0440\u043e \u0438 \u0433\u0440\u044f\u0437\u043d\u043e<\/h3>\n<p>  <img decoding=\"async\" src=\"https:\/\/speakerd.s3.amazonaws.com\/presentations\/aecd8ed08ac00130a95d22000a1e8d60\/slide_15.jpg\" alt=\"Quick&#39;n Dirty\"\/><\/p>\n<p>  \u0415\u0441\u043b\u0438 \u044f \u0441\u043e\u0437\u0434\u0430\u044e \u0434\u043e\u043a\u0430\u0437\u0430\u0442\u0435\u043b\u044c\u0441\u0442\u0432\u043e \u043a\u043e\u043d\u0446\u0435\u043f\u0446\u0438\u0438, \u0442\u0435\u0441\u0442\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u0435 \u0438\u0434\u0435\u0438 \u0438 \u0432\u043e\u043e\u0431\u0449\u0435 \u0445\u0430\u043a\u0430, \u0438\u043b\u0438 \u0441\u043e\u0437\u0434\u0430\u043d\u0438\u044f JS \u00ab\u043d\u0430 \u043f\u043e\u0442\u043e\u043c\u00bb, \u044f \u043e\u0431\u044b\u0447\u043d\u043e \u0434\u043e\u0431\u0430\u0432\u043b\u044f\u044e jQuery \u043f\u043e \u0443\u043c\u043e\u043b\u0447\u0430\u043d\u0438\u044e. \u042d\u0442\u043e \u0441\u043f\u0430\u0441\u0430\u0435\u0442 \u043c\u0435\u043d\u044f \u043e\u0442 \u0440\u0430\u0437\u0434\u0443\u043c\u0438\u0439.<\/p>\n<h2>jQuery-\u0441\u0432\u043e\u0431\u043e\u0434\u0430<\/h2>\n<p>  \u0412\u044b \u043c\u043e\u0436\u0435\u0442\u0435 \u043f\u043e\u0434\u0443\u043c\u0430\u0442\u044c: \u00ab\u0418\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442 \u043b\u0438 \u0420\u0435\u043c\u0438 jQuery, \u0438 \u0435\u0441\u043b\u0438 \u043d\u0435\u0442, \u0442\u043e \u043e\u043d \u043f\u0440\u043e\u0441\u0442\u043e \u0437\u0430\u043d\u043e\u0432\u043e \u0440\u0435\u0430\u043b\u0438\u0437\u0443\u0435\u0442 \u0432\u0441\u0451 \u044d\u0442\u043e?\u00bb.<\/p>\n<p>  \u042f, \u043a\u043e\u043d\u0435\u0447\u043d\u043e, \u043d\u0435 \u0445\u043e\u0447\u0443 \u0437\u0430\u043d\u043e\u0432\u043e \u0438\u0437\u043e\u0431\u0440\u0435\u0442\u0430\u0442\u044c \u043a\u043e\u043b\u0435\u0441\u043e. \u0415\u0441\u043b\u0438 \u044f \u0437\u0430\u043c\u0435\u0447\u0443, \u0447\u0442\u043e \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u043a\u0430 \u0431\u0435\u0437 jQuery \u0442\u043e\u043b\u044c\u043a\u043e \u0438 \u043f\u0440\u0438\u0432\u043e\u0434\u0438\u0442 \u043c\u0435\u043d\u044f \u043a \u043f\u043e\u0432\u0442\u043e\u0440\u0443 \u0431\u043e\u043b\u044c\u0448\u0438\u043d\u0441\u0442\u0432\u0430 \u0444\u0443\u043d\u043a\u0446\u0438\u043e\u043d\u0430\u043b\u044c\u043d\u043e\u0441\u0442\u0438 jQuery \u0441 \u043d\u0443\u043b\u044f, \u0442\u043e \u044f \u043d\u0430\u043f\u0440\u0430\u0441\u043d\u043e \u0442\u0440\u0430\u0447\u0443 \u0432\u043f\u0443\u0441\u0442\u0443\u044e \u0441\u0432\u043e\u0451 \u0441\u043e\u0431\u0441\u0442\u0432\u0435\u043d\u043d\u043e\u0435 \u0432\u0440\u0435\u043c\u044f.<\/p>\n<p>  \u041d\u0435\u0442, \u0435\u0441\u0442\u044c \u043c\u043d\u043e\u0433\u043e \u0448\u0430\u0431\u043b\u043e\u043d\u043e\u0432, \u0433\u0434\u0435 \u044f \u0431\u0443\u0434\u0443 \u043f\u0438\u0441\u0430\u0442\u044c \u0441\u0432\u043e\u0439 \u043a\u043e\u0434 \u043f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u044f \u0431\u0435\u0437 \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0438 \u0438 \u043f\u043e\u043b\u0430\u0433\u0430\u0442\u044c\u0441\u044f \u043d\u0430 \u043d\u0430\u0442\u0438\u0432\u043d\u044b\u0435 \u0442\u0435\u0445\u043d\u043e\u043b\u043e\u0433\u0438\u0438 \u0431\u0440\u0430\u0443\u0437\u0435\u0440\u0430, \u0447\u0442\u043e\u0431\u044b \u0432\u044b\u043f\u043e\u043b\u043d\u0438\u0442\u044c \u0440\u0430\u0431\u043e\u0442\u0443. \u0418 \u0435\u0441\u043b\u0438 \u043d\u0435\u0431\u043e\u043b\u044c\u0448\u0430\u044f \u0447\u0430\u0441\u0442\u044c \u0442\u043e\u0439 \u0444\u0443\u043d\u043a\u0446\u0438\u043e\u043d\u0430\u043b\u044c\u043d\u043e\u0441\u0442\u0438 \u043e\u0442\u0441\u0443\u0442\u0441\u0442\u0432\u0443\u0435\u0442, \u044f \u043c\u043e\u0433 \u0431\u044b \u043e\u0431\u0440\u0430\u0442\u0438\u0442\u044c\u0441\u044f \u043a <a href=\"http:\/\/remysharp.com\/2010\/10\/08\/what-is-a-polyfill\/\">polyfill<\/a> \u2014 \u043d\u043e \u0442\u043e\u043b\u044c\u043a\u043e \u043f\u043e\u0441\u043b\u0435 \u0442\u0449\u0430\u0442\u0435\u043b\u044c\u043d\u043e\u0433\u043e \u0430\u043d\u0430\u043b\u0438\u0437\u0430, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0438\u043c\u0435\u0435\u0442 \u0441\u043c\u044b\u0441\u043b.<\/p>\n<p>  \u0422\u0430\u043a \u043a\u0430\u043a \u044f \u043c\u043e\u0433\u0443 \u0436\u0438\u0442\u044c \u0431\u0435\u0437 jQuery, \u0430 \u043d\u0430\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u0445\u043e\u0440\u043e\u0448\u0430 \u044d\u0442\u0430 \u043f\u043e\u0434\u0434\u0435\u0440\u0436\u043a\u0430?<\/p>\n<h2>document.ready<\/h2>\n<p>  \u0414\u0430\u0436\u0435 \u043a\u043e\u0433\u0434\u0430 \u044f \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044e jQuery, \u0435\u0441\u043b\u0438 \u044f (\u0438\u043b\u0438 \u043c\u043e\u044f \u043a\u043e\u043c\u043f\u0430\u043d\u0438\u044f) \u0438\u043c\u0435\u0435\u0442 \u043a\u043e\u043d\u0442\u0440\u043e\u043b\u044c \u043d\u0430\u0434 \u043f\u0440\u043e\u0435\u043a\u0442\u043e\u043c, \u044f \u043e\u0447\u0435\u043d\u044c, \u043e\u0447\u0435\u043d\u044c \u0440\u0435\u0434\u043a\u043e \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044e <b>document.ready<\/b> (\u0438\u043b\u0438 \u0441\u043e\u043a\u0440\u0430\u0449\u0435\u043d\u043d\u044b\u0439 \u0432\u0430\u0440\u0438\u0430\u043d\u0442 <b>$(function)<\/b>).<\/p>\n<p>  \u041f\u043e\u0442\u043e\u043c\u0443 \u0447\u0442\u043e \u044f \u043f\u043e\u043c\u0435\u0449\u0430\u043b \u0432\u0435\u0441\u044c \u043c\u043e\u0439 JavaScript \u0432\u043d\u0438\u0437 \u043c\u043e\u0435\u0439 DOM \u043f\u0435\u0440\u0435\u0434 \u0437\u0430\u043a\u0440\u044b\u0432\u0430\u044e\u0449\u0438\u043c \u0442\u0435\u0433\u043e\u043c <b>&lt;<\/b><b>\/body&gt;<\/b>. \u041f\u043e\u044d\u0442\u043e\u043c\u0443 \u044f \u0432\u0441\u0435\u0433\u0434\u0430 \u0437\u043d\u0430\u044e, \u0447\u0442\u043e DOM \u0431\u0443\u0434\u0435\u0442 \u0441\u043a\u043e\u043c\u043f\u0438\u043b\u0438\u0440\u043e\u0432\u0430\u043d \u043a \u044d\u0442\u043e\u0439 \u0442\u043e\u0447\u043a\u0435.<\/p>\n<p>  \u041d\u0430\u0434\u0435\u044e\u0441\u044c, \u044d\u0442\u043e \u0438\u0437\u0432\u0435\u0441\u0442\u043d\u043e \u043d\u0430 \u0434\u0430\u043d\u043d\u044b\u0439 \u043c\u043e\u043c\u0435\u043d\u0442, \u043d\u043e JavaScript \u0431\u043b\u043e\u043a\u0438\u0440\u0443\u0435\u0442 \u0440\u0435\u043d\u0434\u0435\u0440\u0438\u043d\u0433. \u041f\u043e\u043c\u0435\u0441\u0442\u0438\u0442\u0435 \u0441\u0432\u043e\u0439 JavaScript \u0432\u044b\u0448\u0435 \u043a\u043e\u043d\u0442\u0435\u043d\u0442\u0430 \u0438 \u0441\u0432\u043e\u0438 \u0441\u0435\u0440\u0432\u0435\u0440\u043d\u044b\u0435 \u043e\u0441\u0442\u0430\u043d\u043e\u0432\u043a\u0438, \u0438 \u0412\u044b \u043f\u043e\u043b\u0443\u0447\u0435\u0442\u0435 \u043f\u0443\u0441\u0442\u0443\u044e \u0441\u0442\u0440\u0430\u043d\u0438\u0446\u0443. \u042f \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043b \u044d\u0442\u043e\u0442 \u043f\u0440\u0438\u043c\u0435\u0440 \u043c\u043d\u043e\u0433\u043e \u0440\u0430\u0437 \u0440\u0430\u043d\u044c\u0448\u0435, \u043d\u043e \u00ab\u0437\u043d\u0430\u0447\u043e\u043a\u00bb Twitter \u0434\u0430\u0432\u043d\u043e \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043b \u0434\u043b\u044f \u0432\u0441\u0442\u0440\u0430\u0438\u0432\u0430\u043d\u0438\u044f \u0432 \u0412\u0430\u0448 HTML. \u0418\u0445 \u0441\u0430\u0439\u0442 \u0447\u0430\u0441\u0442\u043e \u0442\u0435\u0440\u044f\u043b \u0431\u044b \u0440\u0430\u0431\u043e\u0442\u043e\u0441\u043f\u043e\u0441\u043e\u0431\u043d\u043e\u0441\u0442\u044c, \u0438 \u0432 \u043c\u043e\u0451\u043c \u0431\u043b\u043e\u0433\u0435 (\u0442\u0430\u043a\u0436\u0435 \u043f\u0435\u0440\u0435\u043d\u043e\u0441\u044f \u0437\u043d\u0430\u0447\u043e\u043a Twitter) \u0443\u0434\u0430\u0432\u0438\u043b\u0441\u044f \u0431\u044b \u043e\u0442 \u043f\u0443\u0441\u0442\u043e\u0439 \u0441\u0442\u0440\u0430\u043d\u0438\u0446\u044b \u2014 \u0441\u043e\u0437\u0434\u0430\u0432\u0430\u044f \u0432\u043f\u0435\u0447\u0430\u0442\u043b\u0435\u043d\u0438\u0435, \u0447\u0442\u043e \u043c\u043e\u0439 \u0441\u0430\u0439\u0442 \u043d\u0435 \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442.<\/p>\n<h2>.attr(&#8216;value&#8217;) \u0438 .attr(&#8216;href&#8217;)<\/h2>\n<p>  \u041c\u043d\u0435 \u0433\u0440\u0443\u0441\u0442\u043d\u043e, \u043a\u043e\u0433\u0434\u0430 \u044f \u0432\u0438\u0436\u0443 jQuery \u0434\u043b\u044f \u0438\u0437\u0432\u043b\u0435\u0447\u0435\u043d\u0438\u044f \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u044f \u0438\u0437 \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u0430 <b>input<\/b>:  <\/p>\n<pre><code class=\"javascript\">$('input').on('change', function () { \tvar value = $(this).attr('value');  \talert('\u041d\u043e\u0432\u043e\u0435 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435: ' + value); }); <\/code><\/pre>\n<p>  \u041f\u043e\u0447\u0435\u043c\u0443? \u041f\u043e\u0442\u043e\u043c\u0443 \u0447\u0442\u043e \u0412\u044b \u043c\u043e\u0436\u0435\u0442\u0435 \u043f\u043e\u043b\u0443\u0447\u0438\u0442\u044c \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435, \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044f <b>this.value<\/b>. \u0427\u0442\u043e \u0435\u0449\u0435 \u0431\u043e\u043b\u0435\u0435 \u0432\u0430\u0436\u043d\u043e \u2014 \u0412\u0430\u043c \u0441\u043b\u0435\u0434\u0443\u0435\u0442 \u0434\u0443\u043c\u0430\u0442\u044c \u043e \u0442\u043e\u043c, \u043a\u0430\u043a \u0412\u044b \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442\u0435 JavaScript \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0443. \u041d\u0435 \u0432\u044b\u0437\u044b\u0432\u0430\u0439\u0442\u0435 \u0438\u0437\u043b\u0438\u0448\u043d\u0435 jQuery, \u0435\u0441\u043b\u0438 \u043e\u043d \u0412\u0430\u043c \u043d\u0435 \u043d\u0443\u0436\u0435\u043d.<\/p>\n<p>  \u041d\u0430 \u0441\u0430\u043c\u043e\u043c \u0434\u0435\u043b\u0435, \u0434\u0435\u043b\u043e \u043d\u0435 \u0432 jQuery \u2014 \u0434\u0435\u043b\u043e \u0432 \u043f\u0440\u0430\u043a\u0442\u0438\u043a\u0435. \u041a\u043e\u0434 \u0434\u043e\u043b\u0436\u0435\u043d \u0447\u0438\u0442\u0430\u0442\u044c\u0441\u044f \u043f\u0440\u043e\u0449\u0435:  <\/p>\n<pre><code class=\"javascript\">$('input').on('change', function () { \talert('\u041d\u043e\u0432\u043e\u0435 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435: ' + this.value); }); <\/code><\/pre>\n<p>  \u0422\u0430\u043a\u0436\u0435 \u043f\u0440\u0438\u043d\u044f\u0442\u043e \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c jQuery, \u0447\u0442\u043e\u0431\u044b \u043f\u043e\u043b\u0443\u0447\u0438\u0442\u044c <b>href<\/b> \u0438\u0437 \u0441\u0441\u044b\u043b\u043a\u0438: <b>$(this).attr(&#8216;href&#8217;)<\/b>, \u043d\u043e \u0412\u044b \u0442\u0430\u043a\u0436\u0435 \u043c\u043e\u0436\u0435\u0442\u0435 \u043b\u0435\u0433\u043a\u043e \u043f\u043e\u043b\u0443\u0447\u0438\u0442\u044c \u044d\u0442\u043e \u043e\u0442 \u0437\u043d\u0430\u043d\u0438\u044f DOM: <b>this.href<\/b>. \u0422\u0435\u043c \u043d\u0435 \u043c\u0435\u043d\u0435\u0435, \u0437\u0430\u043c\u0435\u0442\u044c\u0442\u0435, \u0447\u0442\u043e <b>this.href<\/b> \u043e\u0442\u043b\u0438\u0447\u0430\u0435\u0442\u0441\u044f, \u044d\u0442\u043e \u0430\u0431\u0441\u043e\u043b\u044e\u0442\u043d\u043e\u0439 URL, \u0430 \u043c\u044b \u0433\u043e\u0432\u043e\u0440\u0438\u043c \u043e DOM API, \u0430 \u043d\u0435 \u043e\u0431 \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u0435. \u0415\u0441\u043b\u0438 \u0412\u0430\u043c \u043d\u0443\u0436\u043d\u043e \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435 \u0430\u0442\u0440\u0438\u0431\u0443\u0442\u0430 (\u043a\u0430\u043a \u044d\u0442\u043e \u043f\u0440\u0435\u0434\u043b\u0430\u0433\u0430\u0435\u0442\u0441\u044f \u0432 \u0432\u0435\u0440\u0441\u0438\u0438 jQuery), \u0412\u0430\u043c \u043f\u043e\u043d\u0430\u0434\u043e\u0431\u0438\u0442\u0441\u044f <b>this.getAttribute(&#8216;href&#8217;)<\/b>.<\/p>\n<p>  \u0414\u0430\u043b\u0435\u0435 \u0435\u0441\u0442\u044c \u0443\u0441\u0442\u0430\u043d\u043e\u0432\u043a\u0430 \u043a\u043b\u0430\u0441\u0441\u0430 \u043d\u0430 \u044d\u043b\u0435\u043c\u0435\u043d\u0442, \u0412\u0430\u043c \u043d\u0435 \u043d\u0443\u0436\u043d\u043e jQuery \u0434\u043b\u044f \u044d\u0442\u043e\u0433\u043e, \u0435\u0441\u043b\u0438 \u0412\u044b \u043f\u0440\u043e\u0441\u0442\u043e \u0434\u043e\u0431\u0430\u0432\u043b\u044f\u0435\u0442\u0435 \u043a\u043b\u0430\u0441\u0441.<\/p>\n<p>  \u042f \u0432\u0438\u0434\u0435\u043b \u044d\u0442\u043e \u0440\u0430\u043d\u044c\u0448\u0435:  <\/p>\n<pre><code class=\"html\">\t&lt;script src=&quot;http:\/\/code.jquery.com\/jquery.min.js&quot;&gt;&lt;\/script&gt; &lt;\/head&gt; &lt;body&gt; \t&lt;script&gt; \t\t$('body').addClass('hasJS'); \t&lt;\/script&gt; <\/code><\/pre>\n<p>  \u041d\u043e \u043f\u043e\u0447\u0435\u043c\u0443 \u0431\u044b \u043d\u0435:  <\/p>\n<pre><code class=\"html\">&lt;\/head&gt; &lt;body&gt; \t&lt;script&gt; \t\tdocument.body.className = 'hasJS'; \t&lt;\/script&gt; <\/code><\/pre>\n<p>  \u0412\u0435\u0440\u043e\u044f\u0442\u043d\u043e, \u043d\u0430\u0438\u0431\u043e\u043b\u0435\u0435 \u0432\u0430\u0436\u043d\u043e\u0435 \u0438\u0437\u043c\u0435\u043d\u0435\u043d\u0438\u0435 \u0432 \u0432\u0430\u0440\u0438\u0430\u043d\u0442\u0435 \u043d\u0438\u0436\u0435 \u2014 \u043d\u0435\u0442 \u043d\u0438\u043a\u0430\u043a\u043e\u0433\u043e jQuery \u0432\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u044f \u0432\u043d\u0430\u0447\u0430\u043b\u0435, \u0447\u0442\u043e\u0431\u044b \u0443\u0441\u0442\u0430\u043d\u043e\u0432\u0438\u0442\u044c \u0438\u043c\u044f \u043a\u043b\u0430\u0441\u0441\u0430 \u043d\u0430 <b>body<\/b>, \u0434\u0430 \u0431\u044b \u043e\u043f\u0440\u0435\u0434\u0435\u043b\u0438\u0442\u044c, \u0434\u043e\u0441\u0442\u0443\u043f\u0435\u043d \u043b\u0438 JavaScript.<\/p>\n<p>  \u0415\u0441\u043b\u0438 \u0443 <b>body<\/b> \u0443\u0436\u0435 \u0438\u043c\u0435\u0435\u0442\u0441\u044f \u043a\u043b\u0430\u0441\u0441, \u0434\u043e\u0441\u0442\u0430\u0442\u043e\u0447\u043d\u043e \u0434\u043e\u0431\u0430\u0432\u0438\u0442\u044c (jQuery \u0434\u043e\u043b\u0436\u0435\u043d \u0441\u0447\u0438\u0442\u044b\u0432\u0430\u0442\u044c \u0441\u0432\u043e\u0439\u0441\u0442\u0432\u043e <b>className<\/b> \u0442\u043e\u0436\u0435): <b>document.body.className += &#8216;hasJS&#8217;<\/b>.<br \/>  \u0418 \u0432\u043e\u0442 \u0442\u0443\u0442 \u043c\u044b \u043d\u0430\u0447\u0438\u043d\u0430\u0435\u043c \u0440\u0430\u0431\u043e\u0442\u0430\u0442\u044c c \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u0430\u043c\u0438 \u0438\u043c\u0451\u043d \u043a\u043b\u0430\u0441\u0441\u043e\u0432 \u0438 \u043e\u0442\u0441\u043b\u0435\u0436\u0438\u0432\u0430\u043d\u0438\u044f, \u043a\u0430\u043a\u0438\u0435 \u043a\u043b\u0430\u0441\u0441\u044b \u043e\u043d\u0438 \u0438\u043c\u0435\u044e\u0442 \u0438 \u043d\u0435 \u0438\u043c\u0435\u044e\u0442. \u041d\u043e \u0431\u0440\u0430\u0443\u0437\u0435\u0440\u044b \u0438\u043c\u0435\u044e\u0442 \u044d\u0442\u0443 \u0444\u0443\u043d\u043a\u0446\u0438\u044e \u0438\u0437\u043d\u0430\u0447\u0430\u043b\u044c\u043d\u043e \u0442\u043e\u0436\u0435.<\/p>\n<h2>classList \u0434\u043b\u044f add, remove \u0438 toggle<\/h2>\n<p>  HTML5 <b>classList<\/b> \u043f\u043e\u0434\u0434\u0435\u0440\u0436\u043a\u0430 \u043f\u0440\u0438\u0441\u0443\u0442\u0441\u0442\u0432\u0443\u0435\u0442 \u0432\u043e \u0432\u0441\u0435\u0445 \u043f\u043e\u0441\u043b\u0435\u0434\u043d\u0438\u0445 \u0431\u0440\u0430\u0443\u0437\u0435\u0440\u0430\u0445 (\u043e\u0431\u0440\u0430\u0442\u0438\u0442\u0435 \u0432\u043d\u0438\u043c\u0430\u043d\u0438\u0435, \u0447\u0442\u043e \u0432 IE9 \u0435\u0451 <i>\u043d\u0435\u0442<\/i> \u2014 \u043d\u043e \u044d\u0442\u043e \u0442\u043e\u0442 \u0441\u043b\u0443\u0447\u0430\u0439, \u043a\u043e\u0433\u0434\u0430 \u044f \u043c\u043e\u0433 \u0431\u044b \u0432\u044b\u0431\u0440\u0430\u0442\u044c polyfill).<br \/>  \u0412\u043c\u0435\u0441\u0442\u043e:  <\/p>\n<pre><code class=\"javascript\">$('body').addClass('hasJS'); \/\/ \u0438\u043b\u0438 document.body.className += ' hasJS'; <\/code><\/pre>\n<p>  \u041c\u044b \u043c\u043e\u0436\u0435\u043c \u0441\u0434\u0435\u043b\u0430\u0442\u044c:  <\/p>\n<pre><code class=\"javascript\">document.body.classList.add('hasJS'); <\/code><\/pre>\n<p>  \u0420\u0430\u0437\u0432\u0435 \u043d\u0435 \u0441\u0438\u043c\u043f\u0430\u0442\u0438\u0447\u043d\u043e?<\/p>\n<p>  \u0427\u0442\u043e \u043a\u0430\u0441\u0430\u0435\u0442\u0441\u044f \u0443\u0434\u0430\u043b\u0435\u043d\u0438\u044f:  <\/p>\n<pre><code class=\"javascript\">$('body').removeClass('hasJS'); \/\/ \u0438\u043b\u0438 \u043a\u0430\u043a\u043e\u0439-\u043b\u0438\u0431\u043e \u0441\u0443\u043c\u0430\u0441\u0448\u0435\u0434\u0448\u0435\u0435 \u0440\u0435\u0433\u0443\u043b\u044f\u0440\u043d\u043e\u0435 \u0432\u044b\u0440\u0430\u0436\u0435\u043d\u0438\u0435 <\/code><\/pre>\n<p>  \u0418\u043b\u0438 \u043c\u044b \u043c\u043e\u0436\u0435\u043c \u0441\u0434\u0435\u043b\u0430\u0442\u044c:  <\/p>\n<pre><code class=\"javascript\">document.body.classList.remove('hasJS'); <\/code><\/pre>\n<p>  \u041d\u043e \u0431\u043e\u043b\u0435\u0435 \u0432\u043d\u0443\u0448\u0438\u0442\u0435\u043b\u044c\u043d\u0435\u0439 \u043d\u0430\u0442\u0438\u0432\u043d\u0430\u044f \u043f\u043e\u0434\u0434\u0435\u0440\u0436\u043a\u0430 \u043f\u0435\u0440\u0435\u043a\u043b\u044e\u0447\u0430\u0442\u0435\u043b\u044f:  <\/p>\n<pre><code class=\"javascript\">document.body.classList.toggle('hasJS'); \/\/ \u0438 document.body.classList.contains('hasJS'); <\/code><\/pre>\n<p>  \u0427\u0442\u043e\u0431\u044b \u0443\u0441\u0442\u0430\u043d\u043e\u0432\u0438\u0442\u044c \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u043a\u043b\u0430\u0441\u0441\u043e\u0432, \u0412\u044b \u043c\u043e\u0436\u0435\u0442\u0435 \u0434\u043e\u0431\u0430\u0432\u0438\u0442\u044c \u0431\u043e\u043b\u044c\u0448\u0435 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0439:  <\/p>\n<pre><code class=\"javascript\">document.body.classList.add('hasJS', 'ready'); <\/code><\/pre>\n<p>  \u0427\u0442\u043e \u0434\u0435\u0439\u0441\u0442\u0432\u0438\u0442\u0435\u043b\u044c\u043d\u043e \u043e\u0442\u0441\u0442\u043e\u0439\u043d\u043e, \u0442\u0430\u043a \u044d\u0442\u043e \u0441\u0442\u0440\u0430\u043d\u043d\u044b\u0435 \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u044b \u043f\u0440\u0438 \u0438\u0437\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u0438 \u043f\u0443\u0441\u0442\u043e\u0439 \u0441\u0442\u0440\u043e\u043a\u0438:  <\/p>\n<pre><code class=\"javascript\">document.body.classList.contains(''); \/\/ SyntaxError: DOM Exception 12 <\/code><\/pre>\n<p>  \u041a\u0440\u0430\u0441\u0438\u0432\u044b\u0439 \u043c\u0443\u0441\u043e\u0440. \u041d\u043e! \u0421 \u0434\u0440\u0443\u0433\u043e\u0439 \u0441\u0442\u043e\u0440\u043e\u043d\u044b \u044f \u0437\u043d\u0430\u044e \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u043d\u044b\u0435 \u043e\u0431\u043b\u0430\u0441\u0442\u0438, \u0438 \u044f \u0438\u0437\u0431\u0435\u0433\u0430\u044e \u0438\u0445. \u0412 \u0437\u043d\u0430\u0447\u0438\u0442\u0435\u043b\u044c\u043d\u043e\u0439 \u0441\u0442\u0435\u043f\u0435\u043d\u0438, \u043c\u044b \u0432\u044b\u0440\u043e\u0441\u043b\u0438 \u0440\u0430\u0431\u043e\u0442\u0430\u044f \u0441 \u0431\u0440\u0430\u0443\u0437\u0435\u0440\u0430\u043c\u0438 \u0442\u0430\u043a \u0438\u043b\u0438 \u0438\u043d\u0430\u0447\u0435.<\/p>\n<h2>\u0425\u0440\u0430\u043d\u0435\u043d\u0438\u0435 \u0434\u0430\u043d\u043d\u044b\u0445<\/h2>\n<p>  <img decoding=\"async\" src=\"https:\/\/speakerd.s3.amazonaws.com\/presentations\/aecd8ed08ac00130a95d22000a1e8d60\/slide_31.jpg\" alt=\"data\"\/><br \/>  jQuery \u0440\u0435\u0430\u043b\u0438\u0437\u043e\u0432\u0430\u043b \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u043b\u044c\u043d\u043e\u0435 \u0445\u0440\u0430\u043d\u0435\u043d\u0438\u0435 \u0434\u0430\u043d\u043d\u044b\u0445 \u0432\u043c\u0435\u0441\u0442\u043e \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u043e\u0432 \u0432 \u0432\u0435\u0440\u0441\u0438\u0438 1.2.3 \u0438 \u0437\u0430\u0442\u0435\u043c \u043e\u0431\u044a\u0435\u043a\u0442\u043d\u043e\u0435 \u0445\u0440\u0430\u043d\u0435\u043d\u0438\u0435 \u0432 \u0432\u0435\u0440\u0441\u0438\u0438 1.4 \u2013 \u0442\u0430\u043a \u043d\u0435\u043a\u043e\u0442\u043e\u0440\u043e\u0435 \u0432\u0440\u0435\u043c\u044f \u043d\u0430\u0437\u0430\u0434.<\/p>\n<p>  \u0412 HTML5 \u0435\u0441\u0442\u044c \u043d\u0430\u0442\u0438\u0432\u043d\u043e\u0435 \u0445\u0440\u0430\u043d\u0435\u043d\u0438\u0435 \u0434\u0430\u043d\u043d\u044b\u0445 \u0432\u043c\u0435\u0441\u0442\u043e \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u043e\u0432, \u043d\u043e \u0435\u0441\u0442\u044c \u043f\u0440\u0438\u043d\u0446\u0438\u043f\u0438\u0430\u043b\u044c\u043d\u043e\u0435 \u0440\u0430\u0437\u043b\u0438\u0447\u0438\u0435 \u043c\u0435\u0436\u0434\u0443 jQuery \u0438 \u043d\u0430\u0442\u0438\u0432\u043d\u043e\u0439 \u043f\u043e\u0434\u0434\u0435\u0440\u0436\u043a\u043e\u0439: \u043e\u0431\u044a\u0435\u043a\u0442\u043d\u043e\u0435 \u0445\u0440\u0430\u043d\u0435\u043d\u0438\u0435 \u043d\u0435 \u0431\u0443\u0434\u0435\u0442 \u0440\u0430\u0431\u043e\u0442\u0430\u0442\u044c \u0432 \u043d\u0430\u0431\u043e\u0440\u0435 \u0434\u0430\u043d\u043d\u044b\u0445 HTML5.<\/p>\n<p>  \u041d\u043e \u0435\u0441\u043b\u0438 \u0412\u044b \u0445\u0440\u0430\u043d\u0438\u0442\u0435 \u0441\u0442\u0440\u043e\u043a\u0438 \u0438\u043b\u0438 JSON, \u0442\u043e\u0433\u0434\u0430 \u043d\u0430\u0442\u0438\u0432\u043d\u0430\u044f \u043f\u043e\u0434\u0434\u0435\u0440\u0436\u043a\u0430 \u0441\u043e\u0432\u0435\u0440\u0448\u0435\u043d\u043d\u0430:  <\/p>\n<pre><code class=\"javascript\">element.dataset.user = JSON.stringify(user); element.dataset.score = score; <\/code><\/pre>\n<p>  \u041f\u043e\u0434\u0434\u0435\u0440\u0436\u043a\u0430 \u0445\u043e\u0440\u043e\u0448\u0430, \u043d\u043e \u043f\u0435\u0447\u0430\u043b\u044c\u043d\u043e \u043d\u0438\u043a\u0430\u043a\u0430\u044f \u043d\u0430\u0442\u0438\u0432\u043d\u0430\u044f \u043f\u043e\u0434\u0434\u0435\u0440\u0436\u043a\u0430 \u0432 IE10 (\u0445\u043e\u0442\u044f \u0412\u044b \u043c\u043e\u0436\u0435\u0442\u0435 \u0434\u043e\u0431\u0430\u0432\u0438\u0442\u044c polyfill \u0438 \u0431\u0443\u0434\u0435\u0442 \u0441\u043d\u043e\u0432\u0430 \u0440\u0430\u0431\u043e\u0442\u0430\u0442\u044c \u043e\u0442\u043b\u0438\u0447\u043d\u043e \u2013 \u043d\u043e \u044d\u0442\u043en \u0441\u043b\u0443\u0447\u0430\u0439 \u043f\u0440\u0438 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u0438 \u043d\u0430\u0431\u043e\u0440\u0430 \u0434\u0430\u043d\u043d\u044b\u0445).<\/p>\n<h2>ajax<\/h2>\n<p>  <img decoding=\"async\" src=\"https:\/\/speakerd.s3.amazonaws.com\/presentations\/aecd8ed08ac00130a95d22000a1e8d60\/slide_33.jpg\" alt=\"ajax\"\/><br \/>  \u041a\u0430\u043a \u044f \u0443\u0436\u0435 \u0433\u043e\u0432\u043e\u0440\u0438\u043b, jQuery \u043f\u043e\u043c\u043e\u0433 \u043c\u043d\u0435 \u043f\u043e\u043b\u043d\u043e\u0441\u0442\u044c\u044e \u043e\u0431\u0440\u0430\u0442\u0438\u0442\u044c \u0432\u043d\u0438\u043c\u0430\u043d\u0438\u0435 \u043d\u0430 ajax. \u041d\u043e \u0442\u0435\u043f\u0435\u0440\u044c ajax \u0434\u043e\u0432\u043e\u043b\u044c\u043d\u043e \u043f\u0440\u043e\u0441\u0442. \u041d\u0435\u0441\u043e\u043c\u043d\u0435\u043d\u043d\u043e, \u0443 \u043c\u0435\u043d\u044f \u043d\u0435\u0442 \u0432\u0441\u0435\u0445 \u0434\u043e\u043f\u043e\u043b\u043d\u0438\u0442\u0435\u043b\u044c\u043d\u044b\u0445 \u043e\u043f\u0446\u0438\u0439, \u043d\u043e \u0434\u043e\u0432\u043e\u043b\u044c\u043d\u043e \u0447\u0430\u0441\u0442\u043e, \u0447\u0435\u043c \u043d\u0435\u0442, \u044f \u0432\u044b\u043f\u043e\u043b\u043d\u044f\u044e XHR GET \u0438\u043b\u0438 POST, \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044f JSON.  <\/p>\n<pre><code class=\"javascript\">function request(type, url, opts, callback) { \tvar xhr = new XMLHttpRequest(), \t\tfd;  \tif (typeof opts === 'function') { \t\tcallback = opts; \t\topts = null; \t}  \txhr.open(type, url);  \tif (type === 'POST' && opts) { \t\tfd = new FormData();  \t\tfor (var key in opts) { \t\t\tfd.append(key, JSON.stringify(opts[key])); \t\t} \t}  \txhr.onload = function () { \t\tcallback(JSON.parse(xhr.response)); \t};  \txhr.send(opts ? fd : null); }  var get = request.bind(this, 'GET'); var post = request.bind(this, 'POST'); <\/code><\/pre>\n<p>  \u042d\u0442\u043e \u043a\u043e\u0440\u043e\u0442\u043a\u043e \u0438 \u044f\u0441\u043d\u043e. XHR \u043d\u0435 \u0441\u043b\u043e\u0436\u043d\u044b\u0439 \u0438 \u043e\u043d \u0445\u043e\u0440\u043e\u0448\u043e \u0437\u0430\u0434\u043e\u043a\u0443\u043c\u0435\u043d\u0442\u0438\u0440\u043e\u0432\u0430\u043d \u0432 \u043d\u0430\u0448\u0435 \u0432\u0440\u0435\u043c\u044f. \u041d\u043e \u0447\u0442\u043e \u0435\u0449\u0435 \u0431\u043e\u043b\u0435\u0435 \u0432\u0430\u0436\u043d\u043e, \u043d\u0430\u043b\u0438\u0447\u0438\u0435 \u043f\u043e\u043d\u0438\u043c\u0430\u043d\u0438\u044f \u0442\u043e\u0433\u043e, \u043a\u0430\u043a \u044d\u0442\u043e \u0434\u0435\u0439\u0441\u0442\u0432\u0438\u0442\u0435\u043b\u044c\u043d\u043e \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u0438 \u0447\u0442\u043e \u043c\u043e\u0436\u0435\u0442 \u0441\u0434\u0435\u043b\u0430\u0442\u044c XHR, \u0434\u0430\u0435\u0442 \u043d\u0430\u043c \u0431\u043e\u043b\u044c\u0448\u0435.<\/p>\n<p>  \u0427\u0442\u043e \u043d\u0430 \u0441\u0447\u0451\u0442 \u043f\u0440\u043e\u0433\u0440\u0435\u0441\u0441\u0430? \u0427\u0442\u043e \u043d\u0430 \u0441\u0447\u0451\u0442 \u0441\u043e\u0431\u044b\u0442\u0438\u0439 \u043f\u0440\u043e\u0433\u0440\u0435\u0441\u0441\u0430 <i>\u0437\u0430\u0433\u0440\u0443\u0437\u043a\u0438<\/i>? \u0427\u0442\u043e \u043d\u0430 \u0441\u0447\u0451\u0442 \u0442\u043e\u0433\u043e, \u0447\u0442\u043e\u0431\u044b \u043e\u0442\u043f\u0440\u0430\u0432\u0438\u0442\u044c \u0438\u0441\u0445\u043e\u0434\u044f\u0449\u0438\u0439 \u043f\u043e\u0442\u043e\u043a \u043a\u0430\u043a <b>ArrayBuffer<\/b>? \u0427\u0442\u043e \u043d\u0430 \u0441\u0447\u0451\u0442 CORS \u0438 <b>xml-requested-with<\/b> \u0437\u0430\u0433\u043e\u043b\u043e\u0432\u043a\u0430?<\/p>\n<p>  \u0412\u0430\u043c \u043f\u043e\u0442\u0440\u0435\u0431\u0443\u0435\u0442\u0441\u044f \u043f\u0440\u044f\u043c\u043e\u0439 \u0434\u043e\u0441\u0442\u0443\u043f \u043a \u043e\u0431\u044a\u0435\u043a\u0442\u0443 XHR \u0434\u043b\u044f \u044d\u0442\u043e\u0433\u043e (\u044f \u0437\u043d\u0430\u044e, \u0447\u0442\u043e \u0412\u044b \u043c\u043e\u0436\u0435\u0442\u0435 \u0434\u043e\u0431\u0438\u0442\u044c\u0441\u044f \u044d\u0442\u043e\u0433\u043e \u0441 \u043f\u043e\u043c\u043e\u0449\u044c\u044e jQuery), \u043d\u043e \u0412\u044b \u0434\u043e\u043b\u0436\u043d\u044b \u043e\u0437\u043d\u0430\u043a\u043e\u043c\u0438\u0442\u044c\u0441\u044f \u0441 \u043e\u0431\u044a\u0435\u043a\u0442\u043e\u043c XHR \u0438 \u044d\u0442\u043e\u0439 \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u043e\u0441\u0442\u044c\u044e, \u043f\u043e\u0442\u043e\u043c\u0443 \u0447\u0442\u043e \u0442\u0430\u043a\u0438\u0435 \u0432\u0435\u0449\u0438, \u043a\u0430\u043a \u0437\u0430\u0433\u0440\u0443\u0437\u043a\u0430 \u0444\u0430\u0439\u043b\u043e\u0432 \u0441 \u043f\u043e\u043c\u043e\u0449\u044c\u044e \u043f\u0435\u0440\u0435\u0442\u0430\u0441\u043a\u0438\u0432\u0430\u043d\u0438\u044f \u0431\u0435\u0437\u0443\u043c\u043d\u043e \u043f\u0440\u043e\u0441\u0442\u044b \u0441 \u043d\u0430\u0442\u0438\u0432\u043d\u043e\u0439 \u0444\u0443\u043d\u043a\u0446\u0438\u043e\u043d\u0430\u043b\u044c\u043d\u043e\u0441\u0442\u044c\u044e \u0441\u0435\u0433\u043e\u0434\u043d\u044f.<\/p>\n<h2>\u041d\u0430\u043a\u043e\u043d\u0435\u0446-\u0442\u043e \u0444\u043e\u0440\u043c\u044b!<\/h2>\n<p>  <img decoding=\"async\" src=\"https:\/\/speakerd.s3.amazonaws.com\/presentations\/aecd8ed08ac00130a95d22000a1e8d60\/slide_38.jpg\" alt=\"\u0424\u043e\u0440\u043c\u044b\"\/><br \/>  jQuery \u043f\u043b\u0430\u0433\u0438\u043d \u0432\u0430\u043b\u0438\u0434\u0430\u0446\u0438\u0438 \u0444\u043e\u0440\u043c \u0431\u044b\u043b \u0443\u0441\u0442\u043e\u0439\u0447\u0438\u0432\u044b\u043c \u043f\u043b\u0430\u0433\u0438\u043d\u043e\u043c \u0441 \u043f\u0435\u0440\u0432\u044b\u0445 \u043b\u0435\u0442 jQuery, \u0438 \u043e\u0442\u043a\u0440\u043e\u0432\u0435\u043d\u043d\u043e \u0441\u0434\u0435\u043b\u0430\u043b \u0440\u0430\u0431\u043e\u0442\u0443 \u0441 \u0444\u043e\u0440\u043c\u0430\u043c\u0438 \u043d\u0430\u0441\u0442\u043e\u043b\u044c\u043a\u043e \u043f\u0440\u043e\u0449\u0435.<\/p>\n<p>  \u041d\u043e \u043d\u0435\u0437\u0430\u0432\u0438\u0441\u0438\u043c\u043e \u043e\u0442 \u0412\u0430\u0448\u0435\u0439 \u043a\u043b\u0438\u0435\u043d\u0442\u0441\u043a\u043e\u0439 \u0432\u0430\u043b\u0438\u0434\u0430\u0446\u0438\u0438 \u2013 \u0412\u044b \u0434\u043e\u043b\u0436\u043d\u044b \u0432\u0441\u0435\u0433\u0434\u0430 \u0432\u044b\u043f\u043e\u043b\u043d\u044f\u0442\u044c \u0432\u0430\u043b\u0438\u0434\u0430\u0446\u0438\u044e \u043d\u0430 \u0441\u0435\u0440\u0432\u0435\u0440\u0435 \u2013 \u044d\u0442\u043e \u043e\u0441\u0442\u0430\u0435\u0442\u0441\u044f \u0438\u0441\u0442\u0438\u043d\u043e\u0439 \u043d\u0435\u0437\u0430\u0432\u0438\u0441\u0438\u043c\u043e \u043e\u0442 \u0442\u043e\u0433\u043e, \u043a\u0430\u043a \u0412\u044b \u043f\u0440\u043e\u0432\u0435\u0440\u044f\u0435\u0442\u0435.<\/p>\n<p>  \u041d\u043e \u0447\u0442\u043e, \u0435\u0441\u043b\u0438 \u0431\u044b \u0412\u044b \u043c\u043e\u0433\u043b\u0438 \u0432\u044b\u0431\u0440\u043e\u0441\u0438\u0442\u044c \u0441\u0442\u0440\u043e\u043a\u0438, \u0441\u0442\u0440\u043e\u043a\u0438 JavaScript \u0438 \u043f\u043b\u0430\u0433\u0438\u043d\u043e\u0432, \u0447\u0442\u043e\u0431\u044b \u0441\u0434\u0435\u043b\u0430\u0442\u044c \u0432\u0430\u043b\u0438\u0434\u0430\u0446\u0438\u044e \u0430\u0434\u0440\u0435\u0441\u0430 \u044d\u043b\u0435\u043a\u0442\u0440\u043e\u043d\u043d\u043e\u0439 \u043f\u043e\u0447\u0442\u044b \u043a\u0430\u043a \u044d\u0442\u0443:  <\/p>\n<pre><code class=\"javascript\">&lt;input type=&quot;email&quot;&gt; <\/code><\/pre>\n<p>  \u0425\u043e\u0442\u0438\u0442\u0435 \u0441\u0434\u0435\u043b\u0430\u0442\u044c \u0435\u0433\u043e \u043e\u0431\u044f\u0437\u0430\u0442\u0435\u043b\u044c\u043d\u044b\u043c \u043f\u043e\u043b\u0435\u043c?  <\/p>\n<pre><code class=\"javascript\">&lt;input type=&quot;email&quot; required&gt; <\/code><\/pre>\n<p>  \u0425\u043e\u0442\u0438\u0442\u0435 \u0440\u0430\u0437\u0440\u0435\u0448\u0438\u0442\u044c \u0442\u043e\u043b\u044c\u043a\u043e \u043e\u043f\u0440\u0435\u0434\u0435\u043b\u0451\u043d\u043d\u044b\u0435 \u0441\u0438\u043c\u0432\u043e\u043b\u044b \u0434\u043b\u044f \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u044f?  <\/p>\n<pre><code class=\"javascript\">&lt;input pattern=&quot;[a-z0-9]&quot;&gt; <\/code><\/pre>\n<p>  \u0415\u0440\u0443\u043d\u0434\u0430. \u042d\u0442\u043e \u0434\u0430\u0436\u0435 \u0438\u0434\u0451\u0442 \u0441 \u0432\u0441\u043f\u043e\u043c\u043e\u0433\u0430\u0442\u0435\u043b\u044c\u043d\u043e\u0439 \u0442\u0435\u0445\u043d\u043e\u043b\u043e\u0433\u0438\u0447\u0435\u0441\u043a\u043e\u0439 \u043f\u043e\u0434\u0434\u0435\u0440\u0436\u043a\u043e\u0439 \u2013 \u0442.\u0435. \u043a\u043b\u0430\u0432\u0438\u0430\u0442\u0443\u0440\u0430 \u0431\u0443\u0434\u0435\u0442 \u043f\u0440\u0438\u0441\u043f\u043e\u0441\u0430\u0431\u043b\u0438\u0432\u0430\u0442\u044c\u0441\u044f \u043a \u0443\u0434\u043e\u0432\u043b\u0435\u0442\u0432\u043e\u0440\u0435\u043d\u0438\u044e \u0441\u0438\u043c\u0432\u043e\u043b\u0430\u043c \u0430\u0434\u0440\u0435\u0441\u0430 \u044d\u043b\u0435\u043a\u0442\u0440\u043e\u043d\u043d\u043e\u0439 \u043f\u043e\u0447\u0442\u044b.<\/p>\n<p>  \u0422\u0430\u043a \u043a\u0430\u043a \u044d\u0442\u0438 \u0442\u0438\u043f\u044b \u0432\u043e\u0437\u0432\u0440\u0430\u0449\u0430\u044e\u0442 <b>text<\/b>, \u0438 \u0443 \u0412\u0430\u0441 <i>\u0434\u043e\u043b\u0436\u043d\u0430<\/i> \u0431\u044b\u0442\u044c \u0432\u0430\u043b\u0438\u0434\u0430\u0446\u0438\u044f \u043d\u0430 \u0441\u0435\u0440\u0432\u0435\u0440\u0435, \u044f <i>\u043d\u0430\u0441\u0442\u043e\u044f\u0442\u0435\u043b\u044c\u043d\u043e<\/i> \u043f\u0440\u0438\u0437\u044b\u0432\u0430\u044e \u0412\u0430\u0441 \u0432\u044b\u0440\u0432\u0430\u0442\u044c \u0432\u0441\u044e \u0441\u0432\u043e\u044e \u0432\u0430\u043b\u0438\u0434\u0430\u044e \u043d\u0430 JavaScript \u0438 \u0437\u0430\u043c\u0435\u043d\u0438\u0442\u044c \u043d\u0430 \u043d\u0430\u0442\u0438\u0432\u043d\u0443\u044e HTML5 \u0432\u0430\u043b\u0438\u0434\u0430\u0446\u0438\u044e \u0444\u043e\u0440\u043c.<\/p>\n<h2>jQuery \u0430\u043d\u0438\u043c\u0430\u0446\u0438\u044f VS. CSS \u0430\u043d\u0438\u043c\u0430\u0446\u0438\u044f VS. JavaScript \u0430\u043d\u0438\u043c\u0430\u0446\u0438\u044f<\/h2>\n<p>  <img decoding=\"async\" src=\"https:\/\/speakerd.s3.amazonaws.com\/presentations\/aecd8ed08ac00130a95d22000a1e8d60\/slide_52.jpg\" alt=\"setInterval VS. requestAnimationFrame\"\/><br \/>  \u042d\u0442\u043e \u043d\u0435 \u0441\u043e\u0432\u0441\u0435\u043c \u043f\u043e\u0435\u0434\u0438\u043d\u043e\u043a. CSS \u043f\u043e\u0431\u0435\u0434\u0438\u043b. CSS \u0430\u043d\u0438\u043c\u0430\u0446\u0438\u044f \u043e\u0431\u0440\u0430\u0431\u0430\u0442\u044b\u0432\u0430\u0435\u0442\u0441\u044f \u0441 \u043f\u043e\u043c\u043e\u0449\u044c\u044e GPU. \u0410\u043d\u0438\u043c\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u0435 \u0432 JavaScript \u0438\u043c\u0435\u0435\u0442 \u0434\u043e\u043f\u043e\u043b\u043d\u0438\u0442\u0435\u043b\u044c\u043d\u044b\u0439 \u0441\u043b\u043e\u0439 \u0432\u044b\u0447\u0438\u0441\u043b\u0435\u043d\u0438\u0439, \u0444\u0430\u043a\u0442\u0438\u0447\u0435\u0441\u043a\u0438 \u0438 \u0435\u0441\u0442\u044c \u0441\u0430\u043c JavaScript.<\/p>\n<p>  \u0414\u0430\u0436\u0435 \u0442\u043e\u0433\u0434\u0430, \u0435\u0441\u043b\u0438 \u044f \u043f\u0438\u0448\u0443 \u043a\u043e\u0434 \u0441\u0430\u043c, \u044f \u0441\u0442\u0430\u0440\u0430\u044e\u0441\u044c \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c <b>requestAnimationFrame<\/b> \u0432\u043c\u0435\u0441\u0442\u043e <b>setInterval<\/b> \u0430\u043d\u0438\u043c\u0430\u0446\u0438\u0438.<\/p>\n<p>  \u0423 \u0414\u0436\u0435\u0439\u043a\u0430 \u0410\u0440\u0447\u0438\u0431\u0430\u043b\u044c\u0434\u0430 \u0435\u0441\u0442\u044c \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u043e\u0442\u043b\u0438\u0447\u043d\u044b\u0445 \u0441\u043b\u0430\u0439\u0434\u043e\u0432, \u043f\u043e\u043a\u0430\u0437\u044b\u0432\u0430\u044e\u0449\u0438\u0435 \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u0443 \u0437\u0434\u0435\u0441\u044c, \u043f\u043e\u0441\u0440\u0435\u0434\u0441\u0442\u0432\u043e\u043c \u0447\u0435\u0433\u043e <b>setInterval<\/b> \u043d\u0435 \u0431\u0443\u0434\u0435\u0442 \u0433\u043b\u0430\u0434\u043a\u0438\u043c \u0438 \u0431\u044b\u0441\u0442\u0440\u043e \u043d\u0430\u0447\u043d\u0435\u0442 \u043e\u0442\u0431\u0440\u0430\u0441\u044b\u0432\u0430\u0442\u044c \u0444\u0440\u0435\u0439\u043c\u044b:<br \/>  <img decoding=\"async\" src=\"https:\/\/speakerd.s3.amazonaws.com\/presentations\/aecd8ed08ac00130a95d22000a1e8d60\/slide_53.jpg\" alt=\"setInterval\"\/><\/p>\n<p>  \u041a \u0442\u043e\u043c\u0443 \u0436\u0435, CSS \u0430\u043d\u0438\u043c\u0430\u0446\u0438\u044f \u043f\u0440\u043e\u0445\u043e\u0434\u0438\u0442 \u0447\u0435\u0440\u0435\u0437 \u0442\u043e\u0433\u043e \u0436\u0435 \u043f\u043b\u0430\u043d\u0438\u0440\u043e\u0432\u0449\u0438\u043a\u0430 \u043a\u0430\u043a <b>requestAnimationFrame<\/b>, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u044f\u0432\u043b\u044f\u0435\u0442\u0441\u044f \u0442\u0435\u043c, \u0447\u0442\u043e \u043c\u044b \u0445\u043e\u0442\u0438\u043c \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c.<\/p>\n<p>  \u0415\u0441\u043b\u0438 \u043f\u043e\u0434\u0434\u0435\u0440\u0436\u043a\u0430 \u0412\u0430\u0448\u0435\u0433\u043e \u0431\u0440\u0430\u0443\u0437\u0435\u0440\u0430 \u043f\u043e\u0437\u0432\u043e\u043b\u044f\u0435\u0442, \u0442\u043e \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0439\u0442\u0435 CSS \u0430\u043d\u0438\u043c\u0430\u0446\u0438\u044e. \u041d\u0435\u0441\u043e\u043c\u043d\u0435\u043d\u043d\u043e, \u044d\u0442\u043e \u043d\u0435 \u0441\u0442\u043e\u043b\u044c \u043f\u0440\u043e\u0441\u0442\u043e, \u043a\u0430\u043a <b>$foo.animate(&#8216;slow&#8217;, { x: &#8216;+=10px&#8217; })<\/b>, \u043d\u043e \u044d\u0442\u043e \u0431\u0443\u0434\u0435\u0442 \u0447\u0438\u0441\u0442\u043e \u0438 \u0433\u043b\u0430\u0434\u043a\u043e. \u0414\u043e\u043b\u0436\u043d\u043e \u0431\u044b\u0442\u044c \u044d\u0442\u043e \u0438\u0437\u0432\u0435\u0441\u0442\u043d\u044b\u0439 \u0444\u0430\u043a\u0442, \u0447\u0442\u043e \u0432\u0437\u0430\u0438\u043c\u043e\u0434\u0435\u0439\u0441\u0442\u0432\u0438\u0435 \u0441 DOM \u0434\u043e\u0440\u043e\u0433\u043e \u043e\u0431\u0445\u043e\u0434\u0438\u0442\u0441\u044f. \u0415\u0441\u043b\u0438 \u0412\u044b \u0430\u043d\u0438\u043c\u0438\u0440\u0443\u0435\u0442\u0435 x \u043f\u043e\u043b\u043e\u0436\u0435\u043d\u0438\u0435 \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u0430 \u043f\u0443\u0442\u0451\u043c \u043e\u0431\u043d\u043e\u0432\u043b\u0435\u043d\u0438\u044f \u0430\u0442\u0440\u0438\u0431\u0443\u0442\u0430 <b>el.style.left<\/b>, \u0412\u044b \u0438\u0434\u0451\u0442\u0435 \u043d\u0430\u0437\u0430\u0434 \u0438 \u0432\u043f\u0435\u0440\u0435\u0434 \u0434\u043b\u044f \u0430\u043d\u0438\u043c\u0430\u0446\u0438\u0438.<\/p>\n<p>  \u041e\u0434\u043d\u0430\u043a\u043e, \u0435\u0441\u043b\u0438 \u0412\u044b \u043c\u043e\u0436\u0435\u0442\u0435 \u043f\u0440\u043e\u0441\u0442\u043e \u0441\u0434\u0435\u043b\u0430\u0442\u044c <b>foo.classList.add(&#8216;animate&#8217;)<\/b>, CSS \u043a\u043b\u0430\u0441\u0441 <b>animate<\/b> \u043f\u0435\u0440\u0435\u0439\u0434\u0435\u0442 <b>left<\/b> \u043f\u043e\u043b\u043e\u0436\u0435\u043d\u0438\u0435 \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u0430. \u0418 \u0443 \u0412\u0430\u0441 \u0435\u0441\u0442\u044c \u043a\u043e\u043d\u0442\u0440\u043e\u043b\u044c, \u0435\u0441\u043b\u0438 \u044d\u0442\u043e \u0442\u043e\u043b\u044c\u043a\u043e \u0441\u0432\u043e\u0439\u0441\u0442\u0432\u043e <b>left<\/b>, \u0438\u043b\u0438 \u0435\u0441\u043b\u0438 \u0412\u044b \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442\u0435 \u043f\u0440\u0435\u0438\u043c\u0443\u0449\u0435\u0441\u0442\u0432\u0435\u043d\u043d\u043e \u0430\u043f\u043f\u0430\u0440\u0430\u0442\u043d\u043e\u0435 \u0443\u0441\u043a\u043e\u0440\u0435\u043d\u0438\u0435 \u043f\u0440\u0438 \u043f\u043e\u043c\u043e\u0449\u0438 <b>translateX<\/b> \u0441 <b>translateZ(0)<\/b>.<\/p>\n<p>  \u041d\u043e \u0447\u0442\u043e \u043a\u0430\u0441\u0430\u0435\u0442\u0441\u044f \u043a\u043e\u043b\u0431\u0435\u043a\u0430 \u043f\u043e \u0437\u0430\u0432\u0435\u0440\u0448\u0435\u043d\u0438\u044e \u0430\u043d\u0438\u043c\u0430\u0446\u0438\u0438, \u044f \u0441\u043b\u044b\u0448\u0443, \u0447\u0442\u043e \u0412\u044b \u0432\u0441\u0435 \u043a\u0440\u0438\u0447\u0438\u0442\u0435?! \u042d\u0442\u043e \u0442\u0430\u043a\u0436\u0435 \u0434\u043e\u0441\u0442\u0443\u043f\u043d\u043e. \u0425\u043e\u0442\u044f \u044d\u0442\u043e \u043d\u0435\u043c\u043d\u043e\u0433\u043e \u043d\u0435\u043f\u0440\u0438\u044f\u0442\u043d\u043e:  <\/p>\n<pre><code class=\"javascript\">el.addEventListener('webkitTransitionEnd', transitionEnded); el.addEventListener('transitionend', transitionEnded); <\/code><\/pre>\n<p>  \u041e\u0431\u0440\u0430\u0442\u0438\u0442\u0435 \u0432\u043d\u0438\u043c\u0430\u043d\u0438\u0435 \u043d\u0430 \u043d\u0438\u0436\u043d\u0438\u0439 \u0440\u0435\u0433\u0438\u0441\u0442\u0440 &#8216;e&#8217; \u0432 &#8216;end&#8217;\u2026<\/p>\n<p>  \u041d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u0434\u043e\u0431\u0440\u044b\u0445 \u043b\u044e\u0434\u0435\u0439 \u043d\u0430 Twitter \u0442\u0430\u043a\u0436\u0435 \u0443\u043a\u0430\u0437\u044b\u0432\u0430\u043b\u0438 \u043c\u043d\u0435 \u043d\u0430 \u043f\u043b\u0430\u0433\u0438\u043d <a href=\"https:\/\/github.com\/benbarnett\/jQuery-Animate-Enhanced\">jquery.animate-enhanced<\/a>, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0443\u043b\u0443\u0447\u0448\u0430\u0435\u0442 \u0444\u0443\u043d\u043a\u0446\u0438\u044e <b>.animate<\/b>, \u0435\u0441\u043b\u0438 CSS \u0430\u043d\u0438\u043c\u0430\u0446\u0438\u044f \u0434\u043e\u0441\u0442\u0443\u043f\u043d\u0430.<\/p>\n<p>  \u0415\u0441\u0442\u044c \u0442\u0430\u043a\u0436\u0435 \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u044b\u0439 \u043f\u043b\u0430\u0433\u0438\u043d \u043f\u043e\u0434 \u043d\u0430\u0437\u0432\u0430\u043d\u0438\u0435\u043c <a href=\"http:\/\/ricostacruz.com\/jquery.transit\/\">Transit<\/a>, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0434\u0430\u0435\u0442 \u0412\u0430\u043c \u0443\u043f\u0440\u0430\u0432\u043b\u0435\u043d\u0438\u0435 \u0441 \u043f\u043e\u043c\u043e\u0449\u044c\u044e JavaScript \u0434\u043b\u044f \u0441\u043e\u0437\u0434\u0430\u043d\u0438\u044f CSS \u0430\u043d\u0438\u043c\u0430\u0446\u0438\u0439. \u0420\u0435\u0430\u043b\u044c\u043d\u043e \u0445\u043e\u0440\u043e\u0448\u0438\u043c \u0430\u0441\u043f\u0435\u043a\u0442\u043e\u043c (\u0434\u043b\u044f \u043c\u0435\u043d\u044f) \u044f\u0432\u043b\u044f\u0435\u0442\u0441\u044f \u043f\u043e\u0434\u0434\u0435\u0440\u0436\u043a\u0430 \u0441\u0446\u0435\u043f\u043b\u0435\u043d\u0438\u044f. \u041f\u043e\u0441\u043a\u043e\u043b\u044c\u043a\u0443 \u043e\u043d \u043e\u0441\u043d\u043e\u0432\u044b\u0432\u0430\u0435\u0442\u0441\u044f \u0438\u0441\u043a\u043b\u044e\u0447\u0438\u0442\u0435\u043b\u044c\u043d\u043e \u043d\u0430 CSS \u0430\u043d\u0438\u043c\u0430\u0446\u0438\u0438, \u044d\u0442\u043e \u0442\u0440\u0435\u0431\u0443\u0435\u0442 IE10 \u0438 \u0432\u044b\u0448\u0435.<\/p>\n<p>  \u0427\u0442\u043e \u043d\u0430\u0432\u043e\u0434\u0438\u0442 \u043c\u0435\u043d\u044f \u043d\u0430 \u043c\u044b\u0441\u043b\u044c: \u043f\u043e\u0447\u0435\u043c\u0443 \u044d\u0442\u043e\u0442 \u043f\u043b\u0430\u0433\u0438\u043d \u0442\u0440\u0435\u0431\u0443\u0435\u0442 jQuery \u0441\u043f\u0435\u0446\u0438\u0430\u043b\u044c\u043d\u043e?<\/p>\n<h2>\u041f\u043b\u0430\u0433\u0438\u043d\u044b jQuery \u2013 \u043f\u0440\u043e\u0441\u0442\u043e \u0442\u0430\u043a<\/h2>\n<p>  <img decoding=\"async\" src=\"https:\/\/speakerd.s3.amazonaws.com\/presentations\/aecd8ed08ac00130a95d22000a1e8d60\/slide_61.jpg\" alt=\"jQuery \u043f\u043b\u0430\u0433\u0438\u043d - \u043f\u0440\u043e\u0441\u0442\u043e \u0442\u0430\u043a\"\/><\/p>\n<p>  \u0426\u0438\u0442\u0430\u0442\u044b \u0438\u0437 \u0442\u0432\u0438\u0442\u0442\u0435\u0440\u0430.<br \/>  <a href=\"https:\/\/speakerd.s3.amazonaws.com\/presentations\/aecd8ed08ac00130a95d22000a1e8d60\/slide_62.jpg\">\u042f:<\/a><\/p>\n<blockquote><p>\u042f \u043d\u0435 \u0437\u043d\u0430\u044e, \u043f\u043e\u0447\u0435\u043c\u0443, \u043d\u043e \u044f \u0434\u0435\u0439\u0441\u0442\u0432\u0438\u0442\u0435\u043b\u044c\u043d\u043e \u0445\u043e\u0447\u0443 \u043f\u0440\u0438\u0447\u0438\u043d\u0438\u0442\u044c \u0431\u043e\u043b\u044c \u043b\u044e\u0434\u044f\u043c, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043f\u0438\u0448\u0443\u0442 jQuery \u043f\u043b\u0430\u0433\u0438\u043d\u044b, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u0434\u0435\u0439\u0441\u0442\u0432\u0438\u0442\u0435\u043b\u044c\u043d\u043e \u043d\u0435 \u043d\u0443\u0436\u0434\u0430\u044e\u0442\u0441\u044f \u0432 jQuery.\/\u0441\u0442\u0440\u0435\u043c\u043b\u044e\u0441\u044c-\u0443\u043f\u0440\u0430\u0432\u043b\u044f\u0442\u044c-\u0433\u043d\u0435\u0432\u043e\u043c<\/p><\/blockquote>\n<p>  \u041e\u0442\u0432\u0435\u0442:<\/p>\n<blockquote><p><a href=\"http:\/\/habrahabr.ru\/users\/rem\/\" class=\"user_link\">rem<\/a> \u042f \u0442\u043e\u0436\u0435, \u044f \u043f\u043e\u0434\u043e\u0437\u0440\u0435\u0432\u0430\u044e, \u0447\u0442\u043e \u0435\u0441\u0442\u044c \u0433\u0440\u0443\u043f\u043f\u0430 \u043f\u043e\u0434\u0434\u0435\u0440\u0436\u043a\u0438 \u0434\u043b\u044f \u044d\u0442\u043e\u0433\u043e. \u0412\u0435\u0440\u043e\u044f\u0442\u043d\u043e, \u0434\u043e\u0432\u043e\u043b\u044c\u043d\u0430 \u0431\u043e\u043b\u044c\u0448\u0430\u044f.<\/p><\/blockquote>\n<p>  \u0412 \u043f\u043e\u0441\u043b\u0435\u0434\u043d\u0435\u0435 \u0432\u0440\u0435\u043c\u044f \u044f \u0440\u0430\u0431\u043e\u0442\u0430\u043b \u043d\u0430\u0434 \u043f\u0440\u043e\u0435\u043a\u0442\u043e\u043c \u0438 \u0437\u043d\u0430\u043b \u043e \u043f\u0440\u043e\u0435\u043a\u0442\u0435 <a href=\"http:\/\/fittextjs.com\/\">fitText.js<\/a>. \u042f \u0441\u043e\u0431\u0438\u0440\u0430\u043b\u0441\u044f \u0431\u0440\u043e\u0441\u0438\u0442\u044c \u0435\u0433\u043e, \u043d\u043e \u0442\u043e\u0433\u0434\u0430 \u044f \u043f\u043e\u043d\u044f\u043b, \u0447\u0442\u043e \u043e\u043d \u043d\u0443\u0436\u0434\u0430\u043b\u0441\u044f \u0432 jQuery.<\/p>\n<p>  \u0425\u043c. \u041f\u043e\u0447\u0435\u043c\u0443?<\/p>\n<p>  \u041e\u043d \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442 \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0438\u0435 jQuery \u043c\u0435\u0442\u043e\u0434\u044b:  <\/p>\n<ol>\n<li><b>.extend<\/b><\/li>\n<li><b>.each<\/b><\/li>\n<li><b>.width<\/b><\/li>\n<li><b>.css<\/b><\/li>\n<li><b>.on<\/b> (\u043d\u0435 \u043c\u043d\u043e\u0433\u043e \u0434\u0443\u043c\u0430\u043b \u043e \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u0434\u0438\u0442\u0435\u043b\u044c\u043d\u043e\u0441\u0442\u0438)<\/li>\n<\/ol>\n<p>  \u0412\u043e\u0442 \u0441\u0430\u043c \u043f\u043b\u0430\u0433\u0438\u043d:  <\/p>\n<pre><code class=\"javascript\">$.fn.fitText = function( kompressor, options ) { \t\/\/ \u0443\u0441\u0442\u0430\u043d\u043e\u0432\u043a\u0430 \u043e\u043f\u0446\u0438\u0439 \tvar compressor = kompressor || 1, \t\tsettings = $.extend({ \t\t  'minFontSize' : Number.NEGATIVE_INFINITY, \t\t  'maxFontSize' : Number.POSITIVE_INFINITY \t\t}, options);  \treturn this.each(function () {  \t  \/\/ \u0441\u043e\u0445\u0440\u0430\u043d\u0435\u043d\u0438\u0435 \u043e\u0431\u044a\u0435\u043a\u0442\u0430 \t  var $this = $(this);  \t  \/\/ resizer() - \u0438\u0437\u043c\u0435\u043d\u044f\u0435\u0442 \u0440\u0430\u0437\u043c\u0435\u0440 \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u043e\u0432, \u0432\u0437\u044f\u0432 \u0448\u0438\u0440\u0438\u043d\u0443 \u043e\u0431\u044a\u0435\u043a\u0442\u0430, \u0434\u0435\u043b\u0451\u043d\u043d\u0443\u044e \u043d\u0430 \u043a\u043e\u043c\u043f\u0440\u0435\u0441\u0441\u043e\u0440 * 10 \t  var resizer = function () { \t\t$this.css('font-size', Math.max(Math.min($this.width() \/ (compressor * 10), parseFloat(settings.maxFontSize)), parseFloat(settings.minFontSize))); \t  };  \t  \/\/ \u0412\u044b\u0437\u044b\u0432\u0430\u0435\u043c \u043e\u0434\u0438\u043d \u0440\u0430\u0437 \u0434\u043b\u044f \u0443\u0441\u0442\u0430\u043d\u043e\u0432\u043a\u0438. \t  resizer();  \t  \/\/ \u0412\u044b\u0437\u044b\u0432\u0430\u0435\u043c \u043f\u0440\u0438 \u0438\u0437\u043c\u0435\u043d\u0435\u043d\u0438\u0438 \u0440\u0430\u0437\u043c\u0435\u0440\u0430. Opera \u043f\u0435\u0440\u0435\u0441\u044b\u043b\u0430\u0435\u0442 \u0438\u0437\u043c\u0435\u043d\u0435\u043d\u0438\u0435 \u0440\u0430\u0437\u043c\u0435\u0440\u043e\u0432 \u043f\u043e \u0443\u043c\u043e\u043b\u0447\u0430\u043d\u0438\u044e. \t  $(window).on('resize orientationchange', resizer);  \t});    }; <\/code><\/pre>\n<p>  <b>.extend<\/b> \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442\u0441\u044f \u0441 \u043e\u0431\u044a\u0435\u043a\u0442\u043e\u043c, \u0443 \u043a\u043e\u0442\u043e\u0440\u043e\u0433\u043e \u0435\u0441\u0442\u044c \u0432\u0441\u0435\u0433\u043e \u0434\u0432\u0435 \u043e\u043f\u0446\u0438\u0438, \u0442\u0430\u043a \u0447\u0442\u043e \u044f \u043f\u0435\u0440\u0435\u043f\u0438\u0441\u0430\u043b \u0431\u044b, \u0447\u0442\u043e\u0431\u044b \u0447\u0438\u0442\u0430\u043b\u043e\u0441\u044c:  <\/p>\n<pre><code class=\"javascript\">if (options === undefined) options = {}; if (options.minFontSize === undefined) options.minFontSize = Number.NEGATIVE_INFINITY; if (options.maxFontSize === undefined) options.maxFontSize = Number.POSITIVE_INFINITY; <\/code><\/pre>\n<p>  <b>return this.each<\/b> \u0440\u0430\u043d\u044c\u0448\u0435 \u0446\u0438\u043a\u043b\u0438\u0447\u043d\u043e \u0432\u044b\u043f\u043e\u043b\u043d\u044f\u043b\u0441\u044f \u043f\u043e \u0443\u0437\u043b\u0430\u043c (nodes). \u0414\u0430\u0432\u0430\u0439\u0442\u0435 \u043f\u0440\u0435\u0434\u043f\u043e\u043b\u043e\u0436\u0438\u043c, \u0447\u0442\u043e \u043c\u044b \u0445\u043e\u0442\u0438\u043c, \u0447\u0442\u043e\u0431\u044b \u044d\u0442\u043e\u0442 \u043a\u043e\u0434 \u0440\u0430\u0431\u043e\u0442\u0430\u043b \u0441\u0430\u043c\u043e\u0441\u0442\u043e\u044f\u0442\u0435\u043b\u044c\u043d\u043e, \u0442\u043e\u0433\u0434\u0430 \u043d\u0430\u0448\u0430 \u0444\u0443\u043d\u043a\u0446\u0438\u044f fitText \u043f\u043e\u043b\u0443\u0447\u0438\u043b\u0430 \u0431\u044b \u0441\u043f\u0438\u0441\u043e\u043a \u0443\u0437\u043b\u043e\u0432 (\u0442\u0430\u043a \u043a\u0430\u043a \u043c\u044b \u043d\u0435 \u0431\u0443\u0434\u0435\u043c \u043e\u0431\u044a\u0435\u0434\u0438\u043d\u044f\u0442\u044c \u0432 \u0446\u0435\u043f\u043e\u0447\u043a\u0443):  <\/p>\n<pre><code class=\"javascript\">var length = nodes.length,  \ti = 0;  \/\/ \u0445\u043e\u0442\u0435\u043b\u043e\u0441\u044c \u0431\u044b \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c [].forEach.call, \u043d\u043e \u043d\u0435\u0442 \u043f\u043e\u0434\u0434\u0435\u0440\u0436\u043a\u0438 \u0432 IE8 for (; i &lt; length; i++) { \t(function (node) { \t\t\/\/ \u0442\u0430\u043c, \u0433\u0434\u0435 \u043c\u044b \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043b\u0438 `this`, \u0442\u0435\u043f\u0435\u0440\u044c \u043c\u044b \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u043c `node` \t\t\/\/ ... \t})(nodes[i]); } <\/code><\/pre>\n<p>  <b>$this.width()<\/b> \u043f\u043e\u043b\u0443\u0447\u0430\u0435\u0442 \u0448\u0438\u0440\u0438\u043d\u0443 \u043a\u043e\u043d\u0442\u0435\u0439\u043d\u0435\u0440\u0430 \u0434\u043b\u044f \u0438\u0437\u043c\u0435\u043d\u0435\u043d\u0438\u044f \u0440\u0430\u0437\u043c\u0435\u0440\u043e\u0432 \u0442\u0435\u043a\u0441\u0442\u0430. \u0422\u0430\u043a\u0438\u043c \u043e\u0431\u0440\u0430\u0437\u043e\u043c, \u043d\u0430\u043c \u043d\u0443\u0436\u043d\u043e \u043f\u043e\u043b\u0443\u0447\u0438\u0442\u044c \u0432\u044b\u0447\u0438\u0441\u043b\u044f\u0435\u043c\u044b\u0435 \u0441\u0442\u0438\u043b\u0438 \u0438 \u0437\u0430\u0445\u0432\u0430\u0442\u0438\u0442\u044c \u0448\u0438\u0440\u0438\u043d\u0443:  <\/p>\n<pre><code class=\"javascript\">\t\/\/ resizer() - \u0438\u0437\u043c\u0435\u043d\u044f\u0435\u0442 \u0440\u0430\u0437\u043c\u0435\u0440 \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u043e\u0432, \u0432\u0437\u044f\u0432 \u0448\u0438\u0440\u0438\u043d\u0443 \u043e\u0431\u044a\u0435\u043a\u0442\u0430, \u0434\u0435\u043b\u0451\u043d\u043d\u0443\u044e \u043d\u0430 \u043a\u043e\u043c\u043f\u0440\u0435\u0441\u0441\u043e\u0440 * 10 \tvar resizer = function () { \tvar width = node.clientWidth;  \t\/\/ ... }; <\/code><\/pre>\n<p>  \u0414\u0435\u0439\u0441\u0442\u0432\u0438\u0442\u0435\u043b\u044c\u043d\u043e \u0432\u0430\u0436\u043d\u043e \u043e\u0442\u043c\u0435\u0442\u0438\u0442\u044c, \u0447\u0442\u043e \u0437\u0430\u043c\u0435\u043d\u0430 <b>.width()<\/b> \u0434\u043b\u044f <b>.clientWidth<\/b> \u043d\u0435 \u0431\u0443\u0434\u0435\u0442 \u0440\u0430\u0431\u043e\u0442\u0430\u0442\u044c \u0432\u043e \u0432\u0441\u0435\u0445 \u043f\u043b\u0430\u0433\u0438\u043d\u0430\u0445. \u041f\u0440\u0430\u0432\u0438\u043b\u044c\u043d\u043e\u0439 \u044d\u0442\u0430 \u0437\u0430\u043c\u0435\u043d\u0430 \u0431\u0443\u0434\u0435\u0442 \u0442\u043e\u043b\u044c\u043a\u043e \u0432 \u0441\u043b\u0443\u0447\u0430\u0435 \u0447\u0430\u0441\u0442\u043d\u043e\u0439 \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u044b, \u043a\u043e\u0442\u043e\u0440\u0443\u044e \u044f \u0440\u0435\u0448\u0430\u043b (\u0447\u0442\u043e \u043f\u043e\u0432\u0442\u043e\u0440\u044f\u0435\u0442 \u043c\u043e\u044e \u0442\u043e\u0447\u043a\u0443 \u0437\u0440\u0435\u043d\u0438\u044f: \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0439\u0442\u0435 \u043f\u0440\u0430\u0432\u0438\u043b\u044c\u043d\u044b\u0439 \u0438\u043d\u0441\u0442\u0440\u0443\u043c\u0435\u043d\u0442 \u0434\u043b\u044f \u0440\u0430\u0431\u043e\u0442\u044b).<\/p>\n<p>  <b>$this.css<\/b> \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442\u0441\u044f \u0432 \u043a\u0430\u0447\u0435\u0441\u0442\u0432\u0435 \u043c\u0435\u0442\u043e\u0434\u0430 <b>set<\/b>, \u0442\u0430\u043a \u0447\u0442\u043e \u044d\u0442\u043e \u043f\u0440\u043e\u0441\u0442\u043e \u0441\u043b\u0443\u0447\u0430\u0439 \u0443\u0441\u0442\u0430\u043d\u043e\u0432\u043a\u0438 \u0441\u0442\u0438\u043b\u044f:  <\/p>\n<pre><code class=\"javascript\">node.style.fontSize = Math.max(...); <\/code><\/pre>\n<p>  <b>$(window).on(&#8216;resize&#8217;, resizer)<\/b> \u0441\u043b\u0443\u0447\u0430\u0439 \u043f\u0440\u0438\u0441\u043e\u0435\u0434\u0438\u043d\u0435\u043d\u0438\u044f \u043e\u0431\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a\u0430 \u0441\u043e\u0431\u044b\u0442\u0438\u0439 (\u043e\u0442\u043c\u0435\u0442\u044c\u0442\u0435, \u0447\u0442\u043e \u0412\u044b \u0445\u043e\u0442\u0435\u043b\u0438 \u0431\u044b <b>addEvent<\/b> \u0442\u0430\u043a\u0436\u0435 \u0434\u043b\u044f \u043f\u043e\u0434\u0434\u0435\u0440\u0436\u043a\u0438 IE8):  <\/p>\n<pre><code class=\"javascript\">window.addEventListener('resize', resizer, false); <\/code><\/pre>\n<p>  \u0424\u0430\u043a\u0442\u0438\u0447\u0435\u0441\u043a\u0438, \u044f \u043f\u043e\u0448\u0435\u043b <a href=\"http:\/\/jsbin.com\/eberan\/9\/edit\">\u0434\u0430\u043b\u044c\u0448\u0435<\/a> \u0438 \u0441\u043e\u0445\u0440\u0430\u043d\u0438\u043b \u0438\u0437\u043c\u0435\u043d\u0451\u043d\u043d\u044b\u0435 \u0440\u0430\u0437\u043c\u0435\u0440\u044b \u0432 \u043c\u0430\u0441\u0441\u0438\u0432\u0435, \u0438 \u043f\u0440\u0438 \u0438\u0437\u043c\u0435\u043d\u0435\u043d\u0438\u0438 \u0440\u0430\u0437\u043c\u0435\u0440\u0430 \u0432\u044b\u043f\u043e\u043b\u043d\u0438\u043b \u0446\u0438\u043a\u043b \u043f\u043e \u043c\u0430\u0441\u0441\u0438\u0432\u0443, \u0432\u044b\u043f\u043e\u043b\u043d\u044f\u044e\u0449\u0438\u0439 \u0444\u0443\u043d\u043a\u0446\u0438\u0438 \u0438\u0437\u043c\u0435\u043d\u0435\u043d\u0438\u044f \u0440\u0430\u0437\u043c\u0435\u0440\u0430.<\/p>\n<p>  \u041d\u0435\u0441\u043e\u043c\u043d\u0435\u043d\u043d\u043e, \u043d\u0435\u043c\u043d\u043e\u0433\u043e \u0431\u043e\u043b\u044c\u0448\u0435 \u0440\u0430\u0431\u043e\u0442\u044b, \u043d\u043e \u044d\u0442\u043e \u0431\u044b\u043b\u043e \u0431\u044b \u0442\u0430\u043a\u0436\u0435 \u043f\u0440\u043e\u0441\u0442\u043e \u043e\u0431\u043d\u043e\u0432\u0438\u0442\u044c \u044d\u0442\u043e \u0438\u0437\u043c\u0435\u043d\u0435\u043d\u0438\u0435, \u0447\u0442\u043e\u0431\u044b \u0438\u0441\u043f\u0440\u0430\u0432\u0438\u0442\u044c \u0432 \u043f\u043b\u0430\u0433\u0438\u043d\u0435 jQuery \u0442\u0430\u043a\u0443\u044e \u043f\u043e\u0434\u0434\u0435\u0440\u0436\u043a\u0443 \u043a\u0430\u043a \u043e\u0431\u043d\u043e\u0432\u043b\u0435\u043d\u0438\u0435, \u0432\u043c\u0435\u0441\u0442\u043e \u0442\u043e\u0433\u043e, \u0447\u0442\u043e\u0431\u044b \u0434\u0435\u043b\u0430\u0442\u044c \u0435\u0433\u043e \u043f\u0440\u0435\u0434\u043f\u043e\u0441\u044b\u043b\u043a\u043e\u0439.<\/p>\n<p>  \u0428\u0443\u043c\u043d\u0430\u044f \u043f\u0440\u043e\u043f\u043e\u0432\u0435\u0434\u044c \u0441\u043a\u043e\u0440\u043e \u0431\u0443\u0434\u0435\u0442 \u0437\u0430\u043a\u043e\u043d\u0447\u0435\u043d\u0430: \u043c\u0435\u043d\u044f \u0442\u0430\u043a\u0436\u0435 \u0440\u0430\u0437\u0434\u0440\u0430\u0436\u0430\u0435\u0442, \u043a\u043e\u0433\u0434\u0430 \u044f \u0432\u0438\u0436\u0443, \u0447\u0442\u043e polyfill \u0442\u0440\u0435\u0431\u0443\u0435\u0442 jQuery \u2013 \u043d\u043e \u044f \u0437\u043d\u0430\u044e, \u0447\u0442\u043e \u043a\u043e\u043d\u0442\u0440\u0430\u0440\u0433\u0443\u043c\u0435\u043d\u0442 \u044d\u0442\u043e\u043c\u0443 \u0442\u043e, \u0447\u0442\u043e \u0443 jQuery \u0435\u0441\u0442\u044c \u0447\u0440\u0435\u0437\u0432\u044b\u0447\u0430\u0439\u043d\u043e \u0432\u044b\u0441\u043e\u043a\u043e\u0435 \u0432\u043d\u0435\u0434\u0440\u0435\u043d\u0438\u0435, \u043f\u043e\u044d\u0442\u043e\u043c\u0443 \u044d\u0442\u043e, \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u043e, \u043e\u043f\u0440\u0430\u0432\u0434\u044b\u0432\u0430\u0435\u0442 \u0437\u0430\u0432\u0438\u0441\u0438\u043c\u043e\u0441\u0442\u044c.<\/p>\n<h2>\u0412 \u0437\u0430\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u0435<\/h2>\n<p>  \u041c\u043e\u044f \u0446\u0435\u043b\u044c \u0441\u043e\u0441\u0442\u043e\u044f\u043b\u0430 \u0432 \u0442\u043e\u043c, \u0447\u0442\u043e\u0431\u044b \u043f\u043e\u043a\u0430\u0437\u0430\u0442\u044c \u0412\u0430\u043c \u0447\u0442\u043e, \u043f\u043e\u043a\u0430 jQuery \u043f\u0440\u043e\u0442\u044f\u043d\u0443\u043b \u043c\u043d\u0435 \u0442\u0430\u043a\u0443\u044e \u043e\u0433\u0440\u043e\u043c\u043d\u0443\u044e \u0440\u0443\u043a\u0443 \u043f\u043e\u043c\u043e\u0449\u0438 \u0437\u0430 \u044d\u0442\u0438 \u0433\u043e\u0434\u044b (\u043e\u0441\u043e\u0431\u0435\u043d\u043d\u043e \u0432 \u0442\u0435 \u0433\u043e\u0434\u044b \u0431\u0435\u0434\u043d\u043e\u0439 \u0441\u043e\u0432\u043c\u0435\u0441\u0442\u0438\u043c\u043e\u0441\u0442\u0438), \u0447\u0442\u043e \u043d\u0430\u0442\u0438\u0432\u043d\u0430\u044f \u043f\u043e\u0434\u0434\u0435\u0440\u0436\u043a\u0430 \u0431\u0440\u0430\u0443\u0437\u0435\u0440\u0430 \u2014 \u0434\u043b\u0438\u043d\u043d\u044b\u0439 \u043f\u0443\u0442\u044c \u043a \u0432\u044b\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u044e \u0431\u043e\u043b\u044c\u0448\u043e\u0433\u043e \u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u0430 \u043e\u0431\u0449\u0438\u0445 \u043f\u043e\u0442\u043e\u043a\u043e\u0432 \u043e\u043f\u0435\u0440\u0430\u0446\u0438\u0439, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u044f \u0438\u043c\u0435\u043b \u043f\u0440\u0438 \u0437\u0430\u043f\u0438\u0441\u0438 JavaScript, \u0447\u0442\u043e\u0431\u044b \u00ab\u0432\u044b\u0442\u0432\u043e\u0440\u044f\u0442\u044c \u0442\u0430\u043a\u043e\u0435\u00bb \u0441 DOM.<\/p>\n<p>  \u0417\u0430\u0431\u0443\u0434\u044c\u0442\u0435 \u043e X \u0444\u0438\u0447\u0435, \u043d\u0435 \u0440\u0430\u0431\u043e\u0442\u0430\u044e\u0449\u0435\u0439 \u0432 \u0431\u0440\u0430\u0443\u0437\u0435\u0440\u0435 Y \u2013 \u043f\u043e\u0434\u043e\u0439\u0434\u0438\u0442\u0435 \u043a \u043d\u0435\u0439 \u0441 \u0442\u043e\u0447\u043a\u0438 \u0437\u0440\u0435\u043d\u0438\u044f: \u0427\u0442\u043e \u044f \u043f\u044b\u0442\u0430\u044e\u0441\u044c \u0440\u0435\u0448\u0438\u0442\u044c? \u041a\u0430\u043a\u043e\u0439 \u0441\u0430\u043c\u044b\u0439 \u043b\u0443\u0447\u0448\u0438\u0439 \u0438\u043d\u0441\u0442\u0440\u0443\u043c\u0435\u043d\u0442 \u0434\u043b\u044f \u044d\u0442\u043e\u0439 \u0440\u0430\u0431\u043e\u0442\u044b? \u041a\u0430\u043a\u0430\u044f \u043c\u043e\u044f \u0430\u0443\u0434\u0438\u0442\u043e\u0440\u0438\u044f?<\/p>\n<p>  \u042f \u0432\u0441\u0451 \u0435\u0449\u0435 \u0432\u0435\u0440\u044e \u0432 \u043f\u0440\u043e\u0433\u0440\u0435\u0441\u0441\u0438\u0432\u043d\u043e\u0435 \u0443\u043b\u0443\u0447\u0448\u0435\u043d\u0438\u0435, \u043d\u043e \u044f \u043d\u0435 \u0432\u0435\u0440\u044e \u0432 \u043d\u0430\u043a\u043b\u043e\u043d \u043d\u0430\u0437\u0430\u0434, \u0447\u0442\u043e\u0431\u044b \u043f\u043e\u0434\u0434\u0435\u0440\u0436\u0438\u0432\u0430\u0442\u044c \u0432\u043e\u043e\u0431\u0440\u0430\u0436\u0430\u0435\u043c\u0443\u044e \u0431\u0430\u0437\u0443 \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u0435\u0439 (\u043f\u043e\u0442\u043e\u043c\u0443 \u0447\u0442\u043e \u0443 \u043d\u0430\u0441 \u043d\u0435\u0442 \u0434\u0430\u043d\u043d\u044b\u0445, \u0447\u0442\u043e\u0431\u044b \u0441\u043a\u0430\u0437\u0430\u0442\u044c, \u043a\u0430\u043a\u0438\u0435 \u0431\u0440\u0430\u0443\u0437\u0435\u0440\u044b \u043d\u0430\u0448\u0438 \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u0438 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044e\u0442).<\/p>\n<p>  Google (\u043f\u043e\u0441\u043b\u0435\u0434\u043d\u0435\u0435, \u0447\u0442\u043e \u044f \u0447\u0438\u0442\u0430\u043b) \u043f\u043e\u0434\u0434\u0435\u0440\u0436\u0438\u0432\u0430\u044e\u0442 \u043f\u043e\u0441\u043b\u0435\u0434\u043d\u0435\u0435 \u043c\u0438\u043d\u0443\u0441 1. \u042f \u0441\u0442\u0430\u0440\u0430\u044e\u0441\u044c \u043d\u0430\u0447\u0430\u0442\u044c \u0441 \u0442\u043e\u0439 \u0436\u0435 \u0431\u0430\u0437\u043e\u0432\u043e\u0439 \u043f\u043e\u0434\u0434\u0435\u0440\u0436\u043a\u0438 \u0442\u043e\u0436\u0435.<\/p>\n<p>  \u042f \u0431\u0443\u0434\u0443 \u043f\u0440\u043e\u0434\u043e\u043b\u0436\u0430\u0442\u044c \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c jQuery, \u0440\u0435\u0448\u0435\u043d\u0438\u0435, \u043a\u043e\u0442\u043e\u0440\u043e\u0435 \u043f\u043e\u0434\u0445\u043e\u0434\u0438\u0442 \u043c\u043d\u0435, \u0438 \u044f \u0431\u0443\u0434\u0443 \u043f\u0440\u043e\u0434\u043e\u043b\u0436\u0430\u0442\u044c \u043f\u0440\u043e\u043f\u043e\u0432\u0435\u0434\u043e\u0432\u0430\u0442\u044c, \u0447\u0442\u043e \u0444\u0440\u043e\u043d\u0442\u0435\u043d\u0434 \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a\u0438 \u0438\u0437\u0443\u0447\u0430\u044e\u0442 \u0442\u043e, \u043a\u0430\u043a\u0438\u0435 \u0431\u0440\u0430\u0443\u0437\u0435\u0440\u044b, \u0441 \u043a\u043e\u0442\u043e\u0440\u044b\u043c\u0438 \u043e\u043d\u0438 \u0440\u0430\u0431\u043e\u0442\u0430\u044e\u0442, \u043d\u0430 \u0447\u0442\u043e \u0441\u043f\u043e\u0441\u043e\u0431\u043d\u044b.<\/p>\n<p>  \u0421 \u044d\u0442\u0438\u043c \u0442\u043e\u0433\u0434\u0430 \u044f \u0437\u0430\u043a\u0440\u0443\u0433\u043b\u044f\u044e\u0441\u044c, \u0438 \u044f \u043d\u0430\u0434\u0435\u044e\u0441\u044c, \u0447\u0442\u043e \u044d\u0442\u043e \u0431\u044b\u043b\u043e \u043f\u043e\u043b\u0435\u0437\u043d\u043e \u0434\u043b\u044f \u0412\u0430\u0441.<\/p>\n<p>  \u0412\u043e\u0437\u043c\u043e\u0436\u043d\u043e \u043d\u0435\u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u0438\u0437 \u0412\u0430\u0441 \u0443\u0436\u0435 \u0437\u043d\u0430\u043b\u0438 \u0432\u0441\u0451 \u044d\u0442\u043e (\u0445\u043e\u0442\u044f \u044f \u043f\u043e\u0434\u0432\u0435\u0440\u0433\u043d\u0443 \u0441\u043e\u043c\u043d\u0435\u043d\u0438\u044e, \u043f\u043e\u0447\u0435\u043c\u0443 \u0412\u044b \u0441\u043b\u0435\u0434\u0438\u0442\u0435\/\u0447\u0438\u0442\u0430\u0435\u0442\u0435 \u044d\u0442\u043e!), \u043d\u0430\u0434\u043e \u043d\u0430\u0434\u0435\u044f\u0442\u044c\u0441\u044f, \u044f \u043f\u043e\u043a\u0430\u0437\u0430\u043b \u043d\u0435\u043a\u043e\u0442\u043e\u0440\u044b\u043c \u0438\u0437 \u0412\u0430\u0441, \u0447\u0442\u043e \u0435\u0441\u0442\u044c \u043c\u0438\u0440 \u0432\u043d\u0435 jQuery \u0438 \u0447\u0442\u043e \u0412\u044b \u043c\u043e\u0436\u0435\u0442\u0435 \u043d\u0430\u0447\u0430\u0442\u044c \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u0435\u0433\u043e \u0441\u0435\u0433\u043e\u0434\u043d\u044f \u0432 \u043a\u0430\u043a\u0438\u0445-\u043b\u0438\u0431\u043e \u0412\u0430\u0448\u0438\u0445 \u043f\u0440\u043e\u0435\u043a\u0442\u0430\u0445.<\/p>\n<p>  \u0412\u043e\u0437\u043c\u043e\u0436\u043d\u043e \u043d\u0435\u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u0438\u0437 \u0412\u0430\u0441 \u043f\u043b\u043e\u0445\u043e \u0437\u043d\u0430\u043a\u043e\u043c\u044b \u0441 jQuery \u2013 \u044f \u043d\u0430\u0434\u0435\u044e\u0441\u044c, \u0447\u0442\u043e \u0412\u044b \u043f\u0440\u043e\u0434\u043e\u043b\u0436\u0430\u0435\u0442\u0435 \u0441\u043c\u043e\u0442\u0440\u0435\u0442\u044c \u0434\u0430\u043b\u044c\u0448\u0435 \u043d\u0430 \u0442\u043e, \u043d\u0430 \u0447\u0442\u043e \u0441\u043f\u043e\u0441\u043e\u0431\u043d\u044b JavaScript \u0438 DOM.<\/p>\n<p>  \u041d\u043e \u0434\u043b\u044f \u0431\u043e\u043b\u044c\u0448\u0438\u043d\u0441\u0442\u0432\u0430 \u0412\u0430\u0441: \u042f \u043f\u043e\u044e \u0432 \u0445\u043e\u0440\u0435. \u0412\u044b \u0443\u0436\u0435 \u043e\u043a\u0440\u0443\u0436\u0435\u043d\u044b. \u0412\u044b \u0443\u0436\u0435 \u0432\u0435\u0440\u0438\u0442\u0435 \u0432 \u0441\u0442\u0430\u043d\u0434\u0430\u0440\u0442\u044b, \u0434\u0435\u043b\u0430\u044f \u044d\u0442\u043e \u043f\u0440\u0430\u0432\u0438\u043b\u044c\u043d\u043e, \u0443\u0447\u0430\u0441\u044c \u0438 \u0443\u043b\u0443\u0447\u0448\u0430\u044f \u0441\u0435\u0431\u044f. \u0418\u043c\u0435\u043d\u043d\u043e \u0442\u0435 \u043b\u044e\u0434\u0438, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 <i>\u043d\u0435<\/i> \u043f\u043e\u043b\u0443\u0447\u0430\u044e\u0442 \u044d\u0442\u0443 \u0438\u043d\u0444\u043e\u0440\u043c\u0430\u0446\u0438\u044e, \u043a\u043e\u0442\u043e\u0440\u043e\u0439 \u043d\u0443\u0436\u043d\u0430 \u0412\u0430\u043c, \u0447\u0442\u043e\u0431\u044b \u043f\u043e\u043c\u043e\u0447\u044c.<\/p>\n<p>  <b>\u0412\u044b<\/b> \u0434\u043e\u043b\u0436\u043d\u044b \u0441\u043e\u0432\u043c\u0435\u0441\u0442\u043d\u043e \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u0441\u0432\u043e\u0439 \u043e\u043f\u044b\u0442 \u0441 \u0434\u0440\u0443\u0433\u0438\u043c\u0438 \u0432\u043e\u043a\u0440\u0443\u0433 \u0412\u0430\u0441. \u0422\u0435\u043f\u0435\u0440\u044c \u0412\u044b \u044d\u043a\u0441\u043f\u0435\u0440\u0442, \u0438 \u0412\u0430\u043c \u0440\u0435\u0448\u0430\u0442\u044c \u043f\u043e\u043c\u043e\u0447\u044c \u0442\u0435\u043c \u0432\u043e\u043a\u0440\u0443\u0433 \u0412\u0430\u0441, \u043f\u043e\u043c\u043e\u0447\u044c \u0438\u043c \u043f\u043e\u0434\u0445\u043e\u0434\u0438\u0442\u044c \u043a \u0412\u0430\u0448\u0438\u043c \u0441\u0442\u0430\u043d\u0434\u0430\u0440\u0442\u0430\u043c \u0438 \u0432\u043d\u0435.<br \/>  \u041a\u043e\u043d\u0444\u0435\u0440\u0435\u043d\u0446\u0438\u0438 \u0431\u0443\u0434\u0443\u0442 \u0438\u0441\u043a\u0430\u0442\u044c \u043d\u043e\u0432\u044b\u0445 \u0434\u043e\u043a\u043b\u0430\u0434\u0447\u0438\u043a\u043e\u0432, \u043d\u043e\u0432\u044b\u0445 \u044d\u043a\u0441\u043f\u0435\u0440\u0442\u043e\u0432: \u0412\u044b \u2014 \u0442\u043e\u0442 \u0447\u0435\u043b\u043e\u0432\u0435\u043a.<\/p>\n<h2>\u0414\u043b\u044f \u043b\u044e\u0431\u0438\u0442\u0435\u043b\u0435\u0439 \u043f\u0440\u043e\u043b\u0438\u0441\u0442\u044b\u0432\u0430\u0442\u044c \u0432 \u0441\u0430\u043c\u044b\u0439 \u043a\u043e\u043d\u0435\u0446<\/h2>\n<p>  \u041d\u0430\u0441\u0442\u0430\u043b\u043e \u0432\u0440\u0435\u043c\u044f \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u043d\u0430\u0442\u0438\u0432\u043d\u044b\u0435 \u0442\u0435\u0445\u043d\u043e\u0433\u0438\u0438 \u0431\u0440\u0430\u0443\u0437\u0435\u0440\u043e\u0432, \u043a\u043e\u0433\u0434\u0430 \u043f\u043e\u044f\u0432\u0438\u043b\u0430\u0441\u044c \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u043e\u0441\u0442\u044c \u043e\u0431\u0445\u043e\u0434\u0438\u0442\u044c\u0441\u044f \u0431\u0435\u0437 jQuery. \u0422\u0430\u043a \u043a\u0430\u043a \u0441\u0442\u0430\u0442\u044c\u044f \u0434\u043e\u0432\u043e\u043b\u044c\u043d\u0430 \u0431\u043e\u043b\u044c\u0448\u0430\u044f, \u0442\u043e \u043d\u0430\u043f\u0440\u0430\u0448\u0438\u0432\u0430\u0435\u0442\u0441\u044f \u043f\u043e\u0434\u0432\u0435\u0441\u0442\u0438 \u0438\u0442\u043e\u0433\u0438:  <\/p>\n<ul>\n<li>\u0418\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0439\u0442\u0435 <b>querySelectorAll<\/b> \u0434\u043b\u044f \u043d\u0430\u0432\u0438\u0433\u0430\u0446\u0438\u0438 \u043f\u043e DOM.<\/li>\n<li>\u0414\u0443\u043c\u0430\u0439\u0442\u0435 \u043e \u0442\u043e\u043c, \u043a\u043e\u0433\u0434\u0430 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c jQuery\/\u043b\u044e\u0431\u0443\u044e \u0434\u0440\u0443\u0433\u0443\u044e \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0443.<\/li>\n<li>\u0418\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0439\u0442\u0435 \u0432\u0441\u0442\u0440\u043e\u0435\u043d\u043d\u044b\u0435 \u0441\u0440\u0435\u0434\u0441\u0442\u0432\u0430 HTML5 \u0434\u043b\u044f \u0432\u0430\u043b\u0438\u0434\u0430\u0446\u0438\u0438 \u0444\u043e\u0440\u043c, \u043d\u043e \u043d\u0435 \u0437\u0430\u0431\u044b\u0432\u0430\u0439\u0442\u0435 \u043f\u0440\u043e\u0432\u0435\u0440\u043a\u0443 \u043d\u0430 \u0441\u0435\u0440\u0432\u0435\u0440\u0435.<\/li>\n<li>\u0417\u0430\u0431\u0443\u0434\u044c\u0442\u0435 \u043f\u0440\u043e <b>document.ready<\/b>, \u043f\u043e\u043c\u0435\u0449\u0430\u0439\u0442\u0435 \u043a\u043e\u0434 \u043f\u0435\u0440\u0435\u0434 \u0437\u0430\u043a\u0440\u044b\u0432\u0430\u044e\u0449\u0438\u043c\u0441\u044f \u0442\u0435\u0433\u043e\u043c <b>&lt;<\/b><b>\/body&gt;<\/b>.<\/li>\n<li>\u0418\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0439\u0442\u0435 <b>this.value<\/b> \u0434\u043b\u044f \u043f\u043e\u043b\u0443\u0447\u0435\u043d\u0438\u044f \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u044f.<\/li>\n<li>\u041f\u043e\u043f\u0440\u043e\u0431\u0443\u0439\u0442\u0435 <b>.classList<\/b> \u0434\u043b\u044f \u0432\u0437\u0430\u0438\u043c\u043e\u0434\u0435\u0439\u0441\u0442\u0432\u0438\u044f \u0441 \u043a\u043b\u0430\u0441\u0441\u0430\u043c\u0438 \u0432\u043c\u0435\u0441\u0442\u043e <b>.css<\/b> \u0438 <b>.className<\/b>.<\/li>\n<li>\u0412\u043d\u0438\u043a\u043d\u0438\u0442\u0435 \u0432 \u0442\u043e, \u043a\u0430\u043a \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442 ajax.<\/li>\n<li>\u0418\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0439\u0442\u0435 \u0430\u043d\u0438\u043c\u0430\u0446\u0438\u044e CSS \u0432\u043c\u0435\u0441\u0442\u043e \u0430\u043d\u0438\u043c\u0430\u0446\u0438\u0438 \u043d\u0430 JavaScript.<\/li>\n<li>\u041c\u043e\u0436\u0435\u0442\u0435 \u043b\u0438 \u0412\u044b \u043e\u0431\u043e\u0439\u0442\u0438\u0441\u044c \u0431\u0435\u0437 jQuery \u0441 \u0441\u0430\u043c\u043e\u0433\u043e \u043d\u0430\u0447\u0430\u043b\u0430?<\/li>\n<\/ul>\n<p>  \u0412 \u043c\u043e\u0451 \u043b\u0438\u0447\u043d\u043e\u0435 \u0437\u0430\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u0435 \u0445\u043e\u0447\u0443 \u043f\u043e\u0437\u0434\u0440\u0430\u0432\u0438\u0442\u044c \u0425\u0430\u0431\u0440\u0430\u0432\u0447\u0430\u043d \u0441 \u0414\u043d\u0451\u043c \u0424\u0440\u0438\u043b\u0430\u043d\u0441\u0435\u0440\u0430! \t\t\t \t\t\t<\/p>\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\/179727\/\"> http:\/\/habrahabr.ru\/post\/179727\/<\/a><\/p>\n","protected":false},"excerpt":{"rendered":"<div class=\"content html_format\">\n<blockquote><p>\u041f\u0435\u0440\u0435\u0432\u043e\u0434 <a href=\"http:\/\/remysharp.com\/2013\/04\/19\/i-know-jquery-now-what\/\">\u0441\u0442\u0430\u0442\u044c\u0438<\/a> \u043e\u0442 <a href=\"http:\/\/remysharp.com\/about\/\">\u0420\u0435\u043c\u0438 \u0428\u0430\u0440\u043f (Remy Sharp)<\/a><br \/>  \u0414\u043b\u044f \u043b\u044e\u0431\u0438\u0442\u0435\u043b\u0435\u0439 \u043f\u0440\u043e\u043b\u0438\u0441\u0442\u044b\u0432\u0430\u0442\u044c \u0432 \u0441\u0430\u043c\u044b\u0439 \u043a\u043e\u043d\u0435\u0446 \u2014 \u0443\u0436\u0435 \u043d\u0430\u043a\u0440\u044b\u0442\u043e.<\/p><\/blockquote>\n<p>  \u042f \u0437\u0430\u0432\u0451\u043b \u044d\u0442\u043e\u0442 \u0440\u0430\u0437\u0433\u043e\u0432\u043e\u0440: &quot;<a href=\"https:\/\/speakerdeck.com\/rem\/i-know-jquery-now-what\">\u042f \u0437\u043d\u0430\u044e jQuery. \u0427\u0442\u043e \u0442\u0435\u043f\u0435\u0440\u044c?<\/a>&quot; \u043d\u0430 <b>jQuery UK 2013<\/b>, \u043d\u043e \u0432\u043c\u0435\u0441\u0442\u043e \u043c\u043e\u0435\u0433\u043e \u043e\u0431\u044b\u0447\u043d\u043e\u0433\u043e \u043f\u043e\u0434\u0445\u043e\u0434\u0430 \u043f\u043e\u0441\u0442-IT \u0432\u0437\u0440\u044b\u0432\u0430 \u043d\u0430 \u043c\u043e\u0435\u043c \u0441\u0442\u043e\u043b\u0435, \u044f \u043d\u0430\u043f\u0438\u0441\u0430\u043b \u0441\u043d\u0430\u0447\u0430\u043b\u0430 \u043f\u043e\u0441\u0442 \u0438 \u0441\u043e\u0437\u0434\u0430\u043b \u043f\u043e \u043d\u0435\u043c\u0443 \u0441\u043b\u0430\u0439\u0434\u044b. \u0422\u0430\u043a \u0432\u043e\u0442, \u043c\u043e\u0438 (\u0434\u043e\u0432\u043e\u043b\u044c\u043d\u043e \u043d\u0435\u043e\u0442\u0440\u0435\u0434\u0430\u043a\u0442\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u044b\u0435) \u043a\u0432\u0430\u0437\u0438-\u043f\u0440\u043e\u0433\u0443\u043b\u043a\u0438 \u043e \u0442\u043e\u043c, \u043a\u0430\u043a \u044f \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043b jQuery \u0438 \u043a\u0430\u043a \u044f \u0441\u043c\u043e\u0442\u0440\u044e \u043d\u0430 \u0442\u043e, \u0433\u0434\u0435 \u044f \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044e \u043d\u0430\u0442\u0438\u0432\u043d\u044b\u0435 \u0442\u0435\u0445\u043d\u043e\u043b\u043e\u0433\u0438\u0438 \u0431\u0440\u0430\u0443\u0437\u0435\u0440\u0430.<br \/>  <img decoding=\"async\" src=\"http:\/\/remysharp.com\/images\/i-know-jquery.jpg\" alt=\"I know jQuery. Now what?\"\/>  <\/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-179727","post","type-post","status-publish","format-standard","hentry"],"_links":{"self":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/179727","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=179727"}],"version-history":[{"count":0,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/179727\/revisions"}],"wp:attachment":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=179727"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=179727"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=179727"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}