diff --git a/index.html b/index.html index 5e60e40..71eb16f 100644 --- a/index.html +++ b/index.html @@ -6,6 +6,39 @@ - +
+ + +
+
Замыкания в JavaScript для начинающих
+

+ Замыкания — это одна из фундаментальных концепций JavaScript, вызывающая сложности у многих новичков, знать и понимать которую должен каждый JS-программист. Хорошо разобравшись с замыканиями, вы сможете писать более качественный, эффективный и чистый код. А это, в свою очередь, будет способствовать вашему профессиональному росту.

+ Материал, перевод которого мы публикуем сегодня, посвящён рассказу о внутренних механизмах замыканий и о том, как они работают в JavaScript-программах. +

+
Что такое замыкание?
+

+ Замыкание — это функция, у которой есть доступ к области видимости, сформированной внешней по отношению к ней функции даже после того, как эта внешняя функция завершила работу. Это значит, что в замыкании могут храниться переменные, объявленные во внешней функции и переданные ей аргументы. Прежде чем мы перейдём, собственно, к замыканиям, разберёмся с понятием «лексическое окружение». +

+
Что такое лексическое окружение?
+

+ Понятие «лексическое окружение» или «статическое окружение» в JavaScript относится к возможности доступа к переменным, функциям и объектам на основе их физического расположения в исходном коде. Рассмотрим пример: +

+ +

+ Здесь у функции inner() есть доступ к переменным, объявленным в её собственной области видимости, в области видимости функции outer() и в глобальной области видимости. Функция outer() имеет доступ к переменным, объявленным в её собственной области видимости и в глобальной области видимости. + Цепочка областей видимости вышеприведённого кода будет выглядеть так: +

+ +

+ Обратите внимание на то, что функция inner() окружена лексическим окружением функции outer(), которая, в свою очередь, окружена глобальной областью видимости. Именно поэтому функция inner() может получить доступ к переменным, объявленным в функции outer() и в глобальной области видимости. +

\ No newline at end of file diff --git a/styles.css b/styles.css index 1cbd2e0..46ca6a8 100644 --- a/styles.css +++ b/styles.css @@ -1,8 +1,148 @@ -/* Тут пиши основные стили */ +img { + margin-left: 362px; + width: 700px; +} + +code { + font-family: "Courier New", monospace; + background-color: #F2F2F2; +} + +p { + font-family: Georgia, Cambria, "Times New Roman", Times, serif; + font-size:21px; + color:rgba(0,0,0,0.84); + text-align:left; + line-height:33px; + width: 700px; + margin-left: 362px; +} + +.header-main { + box-sizing: border-box; + width: 700px; + height: 88px; + font-size:42px; + color:rgba(0,0,0,0.84); + text-align:left; + line-height:44px; + font-family: "Lucida Grande", "Lucida Sans Unicode", "Lucida Sans", Geneva, Arial, sans-serif; + margin: 50px 0 0 360px; + font-weight: 700; +} + +.header-secondary { + font-family: "Lucida Grande", "Lucida Sans Unicode", "Lucida Sans", Geneva, Arial, sans-serif; + font-size: 34px; + color: rgba(0, 0, 0, 0.84); + text-align: left; + line-height: 33px; + font-weight: 700; + margin-left: 360px; + margin-top: 55px; +} + +.logo { + width: 97px; + height: 64px; + margin: 10px 0 10px 38px; +} + +nav ul { + list-style-type: none; + padding-right: 38px; + margin: 0; + background-color: #faf9f8; + height: 80px; + border-top: 1px solid; + border-bottom: 1px solid; + line-height: 80px; +} + +nav ul li { + display: inline-block; + font-family: Georgia, Cambria, "Times New Roman", Times, serif; + font-size:24px; + color:#333333; + text-align:left; + line-height:36px; + margin-right: 30px; +} + +nav ul li:hover{ + text-decoration: underline; + cursor: url("responsive-design\\E8E9A56B-53B7-494E-BE52-747EE607EC62\\5301AFFB-CEE8-43FC-8F06-FB9785DF6E4A@1x.png"), pointer; +} + +nav ul li:visited{ + color: red; +} @media (max-width: 800px) { -/* Тут пиши стили для мобилки. - Стили применятся только когда страничка будет ≤800px шириной - */ + .header-main { + width: 520px; + height: 56px; + font-size:28px; + color:rgba(0,0,0,0.84); + font-family: "Lucida Grande", "Lucida Sans Unicode", "Lucida Sans", Geneva, Arial, sans-serif; + margin: 20px 0 20px 20px; + line-height: 28px; + } + + .header-secondary { + width: 520px; + height: 39px; + font-family: "Lucida Grande", "Lucida Sans Unicode", "Lucida Sans", Geneva, Arial, sans-serif; + font-size: 26px; + color: rgba(0, 0, 0, 0.84); + margin: 25px 0 6px 20px; + line-height: 39px; + } + + p { + font-family: Georgia, Cambria, "Times New Roman", Times, serif; + font-size:18px; + color:rgba(0,0,0,0.84); + margin: 0 20px 0 20px; + line-height: 22px; + } + + img { + margin: 0 20px 0 20px; + width: 520px; + height: 540px; + } + + code { + font-family: "Courier New", monospace; + background-color: #F2F2F2; + } + + .logo { + width: 101px; + height: 64px; + margin: 10px 0 0 20px; + } + + nav ul { + list-style-type: none; + margin: 0; + padding: 0 0 0 20px; + background-color: #faf9f8; + height: 80px; + border-top: 1px solid; + border-bottom: 1px solid; + height: 203px; + } + + header nav ul li { + font-family: Georgia, Cambria, "Times New Roman", Times, serif; + font-size: 20px; + color: #333333; + display: block; + margin: 10px 0 10px 0; + line-height: 25px; + width: auto; + } } \ No newline at end of file