From c57ae2995c6cde880c2f8e3da84129b352b7ec56 Mon Sep 17 00:00:00 2001 From: tarasyyyk Date: Mon, 5 Aug 2019 20:24:38 +0300 Subject: [PATCH 1/4] started translation of 'JavaScript Specials' --- .../16-javascript-specials/article.md | 32 +++++++++---------- 1 file changed, 16 insertions(+), 16 deletions(-) diff --git a/1-js/02-first-steps/16-javascript-specials/article.md b/1-js/02-first-steps/16-javascript-specials/article.md index c2582c51d..d75281eed 100644 --- a/1-js/02-first-steps/16-javascript-specials/article.md +++ b/1-js/02-first-steps/16-javascript-specials/article.md @@ -1,47 +1,47 @@ -# JavaScript specials +# Особливості JavaScript -This chapter briefly recaps the features of JavaScript that we've learned by now, paying special attention to subtle moments. +Давайте коротко повторимо вивчений матеріал і пригадаємо ключові моменти. -## Code structure +## Структура коду -Statements are delimited with a semicolon: +Інструкції розділяються крапкою з комою: ```js run no-beautify -alert('Hello'); alert('World'); +alert('Привіт'); alert('Світ'); ``` -Usually, a line-break is also treated as a delimiter, so that would also work: +Зазвичай, перенесення рядка також вважається за розділювач, тому такий варіант теж працюватиме: ```js run no-beautify -alert('Hello') -alert('World') +alert('Привіт') +alert('Світ') ``` -That's called "automatic semicolon insertion". Sometimes it doesn't work, for instance: +Це називається "автоматичне вставлення крапки з комою". Іноді такий варіант може не спрацювати, наприклад: ```js run -alert("There will be an error after this message") +alert("Після цього повідомлення буде помилка") [1, 2].forEach(alert) ``` -Most codestyle guides agree that we should put a semicolon after each statement. +Більшість посібників по стилю коду рекомендують ставити крапку з комою після кожної інструкції. -Semicolons are not required after code blocks `{...}` and syntax constructs with them like loops: +Крапку з комою не потрібно ставити після блоків коду `{...}` та синтаксичних конструкцій з ними, наприклад, після циклів: ```js function f() { - // no semicolon needed after function declaration + // після оголошення функції не обов'язково ставити крапку з комою } for(;;) { - // no semicolon needed after the loop + // після циклу також немає потреби ставити крапку з комою } ``` -...But even if we can put an "extra" semicolon somewhere, that's not an error. It will be ignored. +...Але навіть якщо ми поставимо "зайву" крапку з комою, помилки не буде. Її просто буде проігноровано. -More in: . +Детальніше: . ## Strict mode From 35496439dcd3c7d178388d2ed90251ff391bf3f6 Mon Sep 17 00:00:00 2001 From: tarasyyyk Date: Tue, 6 Aug 2019 19:23:54 +0300 Subject: [PATCH 2/4] translated 'strict mode', 'variables', 'interaction' --- .../16-javascript-specials/article.md | 80 +++++++++---------- 1 file changed, 40 insertions(+), 40 deletions(-) diff --git a/1-js/02-first-steps/16-javascript-specials/article.md b/1-js/02-first-steps/16-javascript-specials/article.md index d75281eed..3271df362 100644 --- a/1-js/02-first-steps/16-javascript-specials/article.md +++ b/1-js/02-first-steps/16-javascript-specials/article.md @@ -43,87 +43,87 @@ for(;;) { Детальніше: . -## Strict mode +## Суворий режим (Strict mode) -To fully enable all features of modern JavaScript, we should start scripts with `"use strict"`. +Щоб задіяти усі можливості сучасної мови JavaScript, нам потрібно починати скрипти із конструкції `"use strict"`. ```js 'use strict'; -... +...// ваш код ``` -The directive must be at the top of a script or at the beginning of a function. +Ця директива повинна бути зверху скрипта або на початку функції. -Without `"use strict"`, everything still works, but some features behave in the old-fashion, "compatible" way. We'd generally prefer the modern behavior. +Без `"use strict"`, код все ще буде працювати, однак деякі можливості працюватимуть в старому режимі, так званому "режимі сумісності". Ми рекомендуємо використовувати суворий ("сучасний") режим. -Some modern features of the language (like classes that we'll study in the future) enable strict mode implicitly. +Деякі сучасні функції мови (наприклад, класи, які ми будемо вивчати в майбутньому) неявно вмикають суворий режим. -More in: . +Детальніше: . -## Variables +## Змінні -Can be declared using: +Можна оголошувати наступним чином: - `let` -- `const` (constant, can't be changed) -- `var` (old-style, will see later) +- `const` (константа, не можна змінювати) +- `var` (старий спосіб, ми переглянемо його пізніше) -A variable name can include: -- Letters and digits, but the first character may not be a digit. -- Characters `$` and `_` are normal, on par with letters. -- Non-Latin alphabets and hieroglyphs are also allowed, but commonly not used. +Ім'я змінної може включати: +- Літери і цифри; першим символом має бути лише літера, не цифра. +- Допускаються символи `$` та `_`, в парі з літерами. +- Не латинські символи, як кирилиця та ієрогліфи також допускаються, але вони не мають широкого вжитку. -Variables are dynamically typed. They can store any value: +Змінні динамічно типізовані, тобто вони змінюють свій тип в залежності від значення. Можуть зберігати будь-які значення: ```js let x = 5; -x = "John"; +x = "Іван"; ``` -There are 7 data types: +Існує 7 типів даних: -- `number` for both floating-point and integer numbers, -- `string` for strings, -- `boolean` for logical values: `true/false`, -- `null` -- a type with a single value `null`, meaning "empty" or "does not exist", -- `undefined` -- a type with a single value `undefined`, meaning "not assigned", -- `object` and `symbol` -- for complex data structures and unique identifiers, we haven't learnt them yet. +- число (`number`) для цілих та десяткових чисел, +- рядок (`string`) для тексту, +- булевий тип (`boolean`) для логічних значень: `true/false`, +- `null` -- тип з єдиним значенням `null`, який означає "пусто" або "не існує", +- `undefined` -- тип з єдиним значенням `undefined`, який означає "не присвоєно", +- об'єкт (`object`) та символ (`symbol`) -- для складних структур даних та унікальних ідентифікаторів, ми їх ще не вивчили. -The `typeof` operator returns the type for a value, with two exceptions: +Оператор `typeof` повертає тип змінної, за винятком двох випадків: ```js -typeof null == "object" // error in the language -typeof function(){} == "function" // functions are treated specially +typeof null == "object" // помилка в мові +typeof function(){} == "function" // спеціально для функцій ``` -More in: and . +Детальніше: та . -## Interaction +## Взаємодія -We're using a browser as a working environment, so basic UI functions will be: +Ми використовуємо браузер у ролі робочого середовища, тому для взаємодії з користувачами ми використовуємо функції: [`prompt(question, [default])`](mdn:api/Window/prompt) -: Ask a `question`, and return either what the visitor entered or `null` if they clicked "cancel". +: Задає питання (`question`), а потім повертає те, що ввів відвідувач, або `null`, якщо відвідувач натиснув кнопку "Скасувати". [`confirm(question)`](mdn:api/Window/confirm) -: Ask a `question` and suggest to choose between Ok and Cancel. The choice is returned as `true/false`. +: Задає питання (`question`) і пропонує відвідувачу вибрати "ОК" або "Скасувати". Вибір повертається як `true/false`. [`alert(message)`](mdn:api/Window/alert) -: Output a `message`. +: Виводить повідомлення (`message`). -All these functions are *modal*, they pause the code execution and prevent the visitor from interacting with the page until they answer. +Всі ці функції показують *модальне вікно*; вони зупиняють виконання скрипта і не дають користувачеві взаємодіяти зі сторінкою доки не буде надана відповідь. -For instance: +Наприклад: ```js run -let userName = prompt("Your name?", "Alice"); -let isTeaWanted = confirm("Do you want some tea?"); +let userName = prompt("Ваше ім'я?", "Настя"); +let isTeaWanted = confirm("Хочете чаю?"); -alert( "Visitor: " + userName ); // Alice -alert( "Tea wanted: " + isTeaWanted ); // true +alert( "Відвідувач: " + userName ); // Настя +alert( "Хоче чаю: " + isTeaWanted ); // true ``` -More in: . +Детальніше: . ## Operators From f06e84757a6d24e941b2bc116c1b41dd0fd543f3 Mon Sep 17 00:00:00 2001 From: tarasyyyk Date: Tue, 6 Aug 2019 19:28:36 +0300 Subject: [PATCH 3/4] Nastya changed decision --- .../16-javascript-specials/article.md | 14 +++++++------- 1 file changed, 7 insertions(+), 7 deletions(-) diff --git a/1-js/02-first-steps/16-javascript-specials/article.md b/1-js/02-first-steps/16-javascript-specials/article.md index 3271df362..1eaa562ae 100644 --- a/1-js/02-first-steps/16-javascript-specials/article.md +++ b/1-js/02-first-steps/16-javascript-specials/article.md @@ -74,17 +74,17 @@ for(;;) { - Допускаються символи `$` та `_`, в парі з літерами. - Не латинські символи, як кирилиця та ієрогліфи також допускаються, але вони не мають широкого вжитку. -Змінні динамічно типізовані, тобто вони змінюють свій тип в залежності від значення. Можуть зберігати будь-які значення: +Змінні динамічно типізовані, тобто вони змінюють свій тип в залежності від присвоєного значення. Можуть зберігати будь-які значення: ```js -let x = 5; -x = "Іван"; +let x = 5; // присвоєно тип "число" +x = "Іван"; // тип змінився на "рядок" ``` Існує 7 типів даних: - число (`number`) для цілих та десяткових чисел, -- рядок (`string`) для тексту, +- рядок (`string`) для тексту/слів, - булевий тип (`boolean`) для логічних значень: `true/false`, - `null` -- тип з єдиним значенням `null`, який означає "пусто" або "не існує", - `undefined` -- тип з єдиним значенням `undefined`, який означає "не присвоєно", @@ -100,7 +100,7 @@ typeof function(){} == "function" // спеціально для функцій ## Взаємодія -Ми використовуємо браузер у ролі робочого середовища, тому для взаємодії з користувачами ми використовуємо функції: +Ми використовуємо браузер у ролі робочого середовища, тому для взаємодії з відвідувачами ми використовуємо функції: [`prompt(question, [default])`](mdn:api/Window/prompt) : Задає питання (`question`), а потім повертає те, що ввів відвідувач, або `null`, якщо відвідувач натиснув кнопку "Скасувати". @@ -117,10 +117,10 @@ typeof function(){} == "function" // спеціально для функцій ```js run let userName = prompt("Ваше ім'я?", "Настя"); -let isTeaWanted = confirm("Хочете чаю?"); +let isBunWanted = confirm("Хочете булочку?"); alert( "Відвідувач: " + userName ); // Настя -alert( "Хоче чаю: " + isTeaWanted ); // true +alert( "Хоче булочку: " + isBunWanted ); // true ``` Детальніше: . From 64e38900df72c7e800366385da5fdcd838a9cdb3 Mon Sep 17 00:00:00 2001 From: tarasyyyk Date: Mon, 12 Aug 2019 16:22:34 +0300 Subject: [PATCH 4/4] finish translation of 'JavaScript Specials' --- .../16-javascript-specials/article.md | 60 +++++++++---------- 1 file changed, 30 insertions(+), 30 deletions(-) diff --git a/1-js/02-first-steps/16-javascript-specials/article.md b/1-js/02-first-steps/16-javascript-specials/article.md index 47db702b0..f192530fa 100644 --- a/1-js/02-first-steps/16-javascript-specials/article.md +++ b/1-js/02-first-steps/16-javascript-specials/article.md @@ -172,9 +172,9 @@ JavaScript підтримує такі оператори: Детальніше: , , . -## Loops +## Цикли -- We covered 3 types of loops: +- Ми вивчили 3 типи циклів: ```js // 1 @@ -193,42 +193,42 @@ JavaScript підтримує такі оператори: } ``` -- The variable declared in `for(let...)` loop is visible only inside the loop. But we can also omit `let` and reuse an existing variable. -- Directives `break/continue` allow to exit the whole loop/current iteration. Use labels to break nested loops. +- Змінна, оголошена в циклі `for(let...)`, видима лише в циклі. Але ми також можемо опустити `let` і перевикористовувати існуючу змінну. +- Директиви `break/continue` дозволяють вийти з циклу/поточної ітерації. Використовуйте мітки для виходу із вкладених циклів. -Details in: . +Детальніше: . -Later we'll study more types of loops to deal with objects. +Пізніше ми вивчимо більше видів циклів, які працюють з об'єктами. -## The "switch" construct +## Конструкція "switch" -The "switch" construct can replace multiple `if` checks. It uses `===` (strict equality) for comparisons. +Конструкція "switch" може замінити декілька перевірок `if`. Для порівняння, ця конструкція використовує оператор строгого порівняння `===`. -For instance: +Наприклад: ```js run -let age = prompt('Your age?', 18); +let age = prompt('Скільки вам років?', 18); switch (age) { case 18: - alert("Won't work"); // the result of prompt is a string, not a number + alert("Не запрацює"); // результатом prompt є рядок, а не число case "18": - alert("This works!"); + alert("А так запрацює!"); break; default: - alert("Any value not equal to one above"); + alert("Будь-яке значення, нерівне значенням вище"); } ``` -Details in: . +Детальніше: . -## Functions +## Функції -We covered three ways to create a function in JavaScript: +Ми розглянули три способи створення функції в JavaScript: -1. Function Declaration: the function in the main code flow +1. Function Declaration: функція в основному потоці коду ```js function sum(a, b) { @@ -238,7 +238,7 @@ We covered three ways to create a function in JavaScript: } ``` -2. Function Expression: the function in the context of an expression +2. Function Expression: функція як частина виразу ```js let sum = function(a, b) { @@ -248,32 +248,32 @@ We covered three ways to create a function in JavaScript: }; ``` -3. Arrow functions: +3. Стрілкові функції: ```js - // expression at the right side + // вираз в правій частині let sum = (a, b) => a + b; - // or multi-line syntax with { ... }, need return here: + // багаторядковий код в фігурних дужках { ... }, тут потрібен return: let sum = (a, b) => { // ... return a + b; } - // without arguments - let sayHi = () => alert("Hello"); + // без аргументів + let sayHi = () => alert("Привіт"); - // with a single argument + // з одним аргументом let double = n => n * 2; ``` -- Functions may have local variables: those declared inside its body. Such variables are only visible inside the function. -- Parameters can have default values: `function sum(a = 1, b = 2) {...}`. -- Functions always return something. If there's no `return` statement, then the result is `undefined`. +- У функцій можуть бути локальні змінні: тобто ті, які оголошені в тілі функції. Такі змінні видимі лише всередині функції. +- Параметри можуть мати усталені значення: `function sum(a = 1, b = 2) {...}`. +- Функції завжди щось повертають. Якщо всередині функції немає оператора `return`, тоді вона поверне `undefined`. -Details: see , . +Детальніше: дивіться , . -## More to come +## Ми вивчемо більше -That was a brief list of JavaScript features. As of now we've studied only basics. Further in the tutorial you'll find more specials and advanced features of JavaScript. +Це був короткий перелік можливостей JavaScript. Цієї миті ми вивчили лише основи. Далі в посібнику ви знайдете більше особливостей і просунутих можливостей JavaScript. pFad - Phonifier reborn

Pfad - The Proxy pFad of © 2024 Garber Painting. All rights reserved.

Note: This service is not intended for secure transactions such as banking, social media, email, or purchasing. Use at your own risk. We assume no liability whatsoever for broken pages.


Alternative Proxies:

Alternative Proxy

pFad Proxy

pFad v3 Proxy

pFad v4 Proxy