diff --git a/modules/10-basics/45-testing/en/README.md b/modules/10-basics/45-testing/en/README.md index 14404b68..98985d51 100644 --- a/modules/10-basics/45-testing/en/README.md +++ b/modules/10-basics/45-testing/en/README.md @@ -24,8 +24,8 @@ One of your tasks in the following lessons will be to write a function that perf "ello, World!" -In addition to our tests, it's very useful to experiment with code in the [browser console](https://developer.mozilla.org/en-US/docs/Tools/Browser_Console). When something isn't clear to you or you want to experiment with code, feel free to do all of this in the console. Ideally, it's best to execute all the code given in the lessons on your own. In addition to the console, you can also use [repl.it](https://repl.it/languages/javascript). +In addition to our tests, it's very useful to experiment with code in the [browser console](https://developer.mozilla.org/en-US/docs/Tools/Browser_Console). When something isn't clear to you, or you want to experiment with code, feel free to do all of this in the console. Ideally, it's best to execute all the code given in the lessons on your own. In addition to the console, you can also use [repl.it](https://repl.it/languages/javascript). Sometimes when creating a solution, it may seem that you have done everything correctly, but the system has got into a huff and won't accept your solution. Such cases are borderline impossible. Failed tests simply won't get as far as the site, they are automatically run after each change. In the vast majority of cases (all our projects have been run millions of times in total over many years) the error is in the solution code. It can be very imperceptible, maybe you used the wrong punctuation, or you used upper case instead of lower case, or you missed a comma. Other cases are more complicated. Maybe your solution works for one set of inputs, but not for another. So always read the instructions and test your output carefully. There will almost certainly be some sign of an error. -However, if you are sure about a mistake or have found an inaccuracy, you can always point it out. At the end of each theory section, there is a link to the contents of the lesson on Github (this project is completely open-source!). You can write about an issue, look through the tests (you can see how your code is called there), and even send a pull request. If it's all gone over your head, then join the #hexlet-feedback channel in [Slack community](https://slack.hexlet.io/), where we'll always be ready to help you. +However, if you are sure about a mistake or have found an inaccuracy, you can always point it out. At the end of each theory section, there is a link to the contents of the lesson on GitHub (this project is completely open-source!). You can write about an issue, look through the tests (you can see how your code is called there), and even send a pull request. If it's all gone over your head, then join the #hexlet-feedback channel in [Slack community](https://slack.hexlet.io/), where we'll always be ready to help you. diff --git a/modules/10-basics/50-syntax-errors/en/README.md b/modules/10-basics/50-syntax-errors/en/README.md index 0692d240..215ef9ed 100644 --- a/modules/10-basics/50-syntax-errors/en/README.md +++ b/modules/10-basics/50-syntax-errors/en/README.md @@ -1,4 +1,4 @@ -If a JavaScript program is syntactically incorrect, the interpreter will show a relevant message and a message showing the file and line where the error might have occurred. **Syntax errors** occur when the code has grammatical mistakes. Grammar is essential to human language, but a text with grammar mistakes can still be read and understood. However, when it comes to programming, things are much more strict. Even a tiny mistake can mean your program won't run. Maybe you've mixed up your brackets, or there's a `;` that you forgot to add — these are just some examples of such mistakes. +If a JavaScript program is syntactically incorrect, the interpreter will show a relevant message and a message showing the file and line where the error might have occurred. **Syntax errors** occur when the code has grammatical mistakes. Grammar is essential to human language, but a text with grammar mistakes can still be read and understood. However, when it comes to programming, things are much stricter. Even a tiny mistake can mean your program won't run. Maybe you've mixed up your brackets, or there's a `;` that you forgot to add — these are just some examples of such mistakes. Here is an example of some code with a syntax error: diff --git a/modules/20-arithmetics/20-basic/en/README.md b/modules/20-arithmetics/20-basic/en/README.md index 37bde782..de77aaf5 100644 --- a/modules/20-arithmetics/20-basic/en/README.md +++ b/modules/20-arithmetics/20-basic/en/README.md @@ -23,7 +23,7 @@ After launching, the result will appear on the screen: 7 ``` -Besides addition, the following operations are available: +The following operations are available besides addition: `*` — multiplication `/` — division `-` — subtraction diff --git a/modules/20-arithmetics/50-float/en/README.md b/modules/20-arithmetics/50-float/en/README.md index 80b0c3a6..17e43844 100644 --- a/modules/20-arithmetics/50-float/en/README.md +++ b/modules/20-arithmetics/50-float/en/README.md @@ -20,6 +20,6 @@ console.log(Number.MAX_SAFE_INTEGER); 9007199254740991 ``` -Rational numbers are not lined up in a continuous chain like integers, there's an infinite amount of numbers between _0.1_ and _0.2_. So now we have a big problem: how can we store rational numbers? Excellent question. There is a myriad of articles in the internet about memory organization in these cases. Moreover, there is even a standard describing how to do it correctly, and an overwhelming number of languages are based on this set of recommendations. +Rational numbers are not lined up in a continuous chain like integers, there's an infinite amount of numbers between _0.1_ and _0.2_. So now we have a big problem: how can we store rational numbers? Excellent question. There is a myriad of articles on the internet about memory organization in these cases. Moreover, there is even a standard describing how to do it correctly, and an overwhelming number of languages are based on this set of recommendations. As developers, it's important to understand that operations with floating numbers are not precise (though precision can be adjusted using special tricks). diff --git a/modules/20-arithmetics/80-linting/en/README.md b/modules/20-arithmetics/80-linting/en/README.md index 1712fb3f..3c727923 100644 --- a/modules/20-arithmetics/80-linting/en/README.md +++ b/modules/20-arithmetics/80-linting/en/README.md @@ -1,6 +1,6 @@ Since we've learned to write simple programs, let's talk about the very process of writing. -The program code should be organized in a certain way so that it is sufficiently clear and easy to maintain. Special sets of rules - standards - describe different aspects of code writing. The most common standard in JavaScript is [AirBnb](https://github.com/airbnb/javascript). +The program code should be organized in a certain way so that it is sufficiently clear and easy to maintain. Special sets of rules - standards - describe different aspects of code writing. The most common standard in JavaScript is [Airbnb](https://github.com/airbnb/javascript). In any programming language, there are utilities known as **linters**. They ensure the code meets the standards. For example, [ESLint](https://eslint.org/) analyzes JavaScript code. @@ -15,7 +15,7 @@ Linter won't be happy about it, because several rules have been violated: * [space-infix-ops](https://eslint.org/docs/rules/space-infix-ops) – No space between operator and operands * [no-mixed-operators](https://eslint.org/docs/rules/no-mixed-operators) – You can't write code that contains multiple operations in a single expression with no explicit parentheses separation -In the last lesson we recognized that such an abundance of numbers and symbols may be confusing and we decided to add parentheses purely for the sake of readability: +In the last lesson we recognized that such an abundance of numbers and symbols may be confusing, and we decided to add parentheses purely for the sake of readability: ```javascript console.log(((8 / 2) + 5) - (-3 / 2)); // => 10.5 @@ -35,4 +35,4 @@ Unfortunately, yes. This time, the `*` and `/` are in the same expression and th [no-mixed-operators](https://eslint.org/docs/rules/no-mixed-operators) is just one of many rules. Other ones describe indentations, entity names, parentheses, mathematical operations, line length, and many other aspects. Each rule may seem small and insignificant, but together they form the basis of good code. -CodeBasics won't test your code with a linter now, but in your future Hexlet practice segments and in actual development, the linter will work and flag the bugs. +Code-Basics won't test your code with a linter now, but in your future Hexlet practice segments and in actual development, the linter will work and flag the bugs. diff --git a/modules/25-strings/15-escape-characters/en/README.md b/modules/25-strings/15-escape-characters/en/README.md index 10f0ba4a..c8b6f5a6 100644 --- a/modules/25-strings/15-escape-characters/en/README.md +++ b/modules/25-strings/15-escape-characters/en/README.md @@ -42,9 +42,9 @@ The result: '\n\n'.length; // 2 !!! ``` -Why is it done in this way? `\n` is just a way to write a line break symbol. That's why line feed is just one character, just invisible. And it's also why this problem has arisen. There had to be a way of representing it using a keyboard. And since the number of keyboard characters is limited and they're all dedicated to very important things, special characters are entered using these escape sequences. +Why is it done in this way? `\n` is just a way to write a line break symbol. That's why line feed is just one character, just invisible. And it's also why this problem has arisen. There had to be a way of representing it using a keyboard. And since the number of keyboard characters is limited, and they're all dedicated to very important things, special characters are entered using these escape sequences. -The Line Feed symbol is not something specific to programming. Anyone who has ever typed on a computer has used the line feed by clicking Enter. Many editors can display these invisible characters, you can use this feature to see where they are (though it's only for display, these characters are invisible, they've no graphical representation): +The Line Feed symbol is not something specific to programming. Anyone who has ever typed on a computer has used the line feed by clicking Enter. Many editors can display these invisible characters, you can use this feature to see where they are (though it's only for display, these characters are invisible, they have no graphical representation):
 - Hi!¶
@@ -124,4 +124,4 @@ The result:
 Joffrey loves using \n
 
-A small but important note about Windows. Windows uses `\r\n` by default to enter a line break. This combination works well in Windows but creates problems when copied to other systems (for example, when the development team includes both Windows and Linux users). The point is that the sequence `\r\n` has a different interpretation depending on the encoding chosen (we discuss it later). For this reason, it's common among developers to always use `\n` without `\r`, since it means that LF is always interpreted the same way and works fine on any system. Remember to configure your editor to use `\n`. +A small but important note about Windows. Windows uses `\r\n` by default to enter a line break. This combination works well on Windows but creates problems when copied to other systems (for example, when the development team includes both Windows and Linux users). The point is that the sequence `\r\n` has a different interpretation depending on the encoding chosen (we discuss it later). For this reason, it's common among developers to always use `\n` without `\r`, since it means that LF is always interpreted the same way and works fine on any system. Remember to configure your editor to use `\n`. diff --git a/modules/25-strings/30-encoding/en/EXERCISE.md b/modules/25-strings/30-encoding/en/EXERCISE.md index 387d1252..c27df311 100644 --- a/modules/25-strings/30-encoding/en/EXERCISE.md +++ b/modules/25-strings/30-encoding/en/EXERCISE.md @@ -7,7 +7,7 @@ console.log(String.fromCharCode(63)); Character 63 will be printed - a question mark. You can print any character this way. -Find an ASCII table on the internet. You can use queries like "ascii codes table" or "ascii codes". Generally, these tables give codes in several number systems: decimal, binary, octal and hexadecimal. We are interested in the decimal code (*dec* or *decimal*). +Find an ASCII table on the internet. You can use queries like "ASCII codes table" or "ASCII codes". Generally, these tables give codes in several number systems: decimal, binary, octal and hexadecimal. We are interested in the decimal code (*dec* or *decimal*). Using the example above and the table you found, print the characters `~`, `^` and `%` (each on their own line). diff --git a/modules/25-strings/30-encoding/en/README.md b/modules/25-strings/30-encoding/en/README.md index 64eff811..1567833c 100644 --- a/modules/25-strings/30-encoding/en/README.md +++ b/modules/25-strings/30-encoding/en/README.md @@ -32,6 +32,6 @@ Different encodings have different numbers of characters. At first, small tables With the development of computers, different countries needed their own comprehensive tables. Including Cyrillic letters, hieroglyphs, Arabic script, additional mathematical and typographic characters, and even emojis as time went on. -One [Unicode standarts](https://en.wikipedia.org/wiki/Unicode) standard in particular, *utf-8*, is the one used in most cases today. It includes characters from almost all of the written languages found in the world. Therefore, a letter written by someone from China in Chinese can easily be opened and read natively on a computer in Finland (whether the reader would understand it or not is another question). +One [Unicode standards](https://en.wikipedia.org/wiki/Unicode) standard in particular, *utf-8*, is the one used in most cases today. It includes characters from almost all the written languages found in the world. Therefore, a letter written by someone from China in Chinese can easily be opened and read natively on a computer in Finland (whether the reader would understand it or not is another question). Programmers have to deal with encodings regularly. Unicode support in different programming languages is carried out on a different level. Moreover, encodings must be declared when working with databases and files. diff --git a/modules/30-variables/15-variables-expressions/en/EXERCISE.md b/modules/30-variables/15-variables-expressions/en/EXERCISE.md index 9065745b..563d4d2e 100644 --- a/modules/30-variables/15-variables-expressions/en/EXERCISE.md +++ b/modules/30-variables/15-variables-expressions/en/EXERCISE.md @@ -1,5 +1,5 @@ -Write a program that takes the initial amount of euros stored in the variable `eurosCount`, converts euros to dollars, and prints it. Then, it should convert the result to yuans and print it on a new line. +Write a program that takes the initial amount of euros stored in the variable `eurosCount`, converts euros to dollars, and prints it. Then, it should convert the result to yuan and print it on a new line. Sample output for 100 euros: @@ -10,4 +10,4 @@ Sample output for 100 euros: Suppose that: - 1 euro = 1.25 dollars -- 1 dollar = 6.91 yuans +- 1 dollar = 6.91 yuan diff --git a/modules/30-variables/15-variables-expressions/en/README.md b/modules/30-variables/15-variables-expressions/en/README.md index aaab7295..676c4328 100644 --- a/modules/30-variables/15-variables-expressions/en/README.md +++ b/modules/30-variables/15-variables-expressions/en/README.md @@ -1,5 +1,5 @@ -Variables are helpful not only for storing and reusing data but also for simplifying complex calculations. Consider an example: you need to convert euros into yuans through dollars. Banks often do this kind of conversion via an intermediate currency when shopping abroad. +Variables are helpful not only for storing and reusing data but also for simplifying complex calculations. Consider an example: you need to convert euros into yuan through dollars. Banks often do this kind of conversion via an intermediate currency when shopping abroad. First, convert 50 euros into dollars. Suppose that one euro is $1.25: @@ -34,28 +34,28 @@ console.log(who); Run it on [repl.it](https://repl.it/languages/javascript) and experiment a little with it. -Now, back to our currency program. We'll record the dollar value in yuans as a separate variable. Calculate the value of 50 euros in dollars by multiplying them by `1.25`. Suppose that 1 dollar is 6.91 yuans: +Now, back to our currency program. We'll record the dollar value in yuan as a separate variable. Calculate the value of 50 euros in dollars by multiplying them by `1.25`. Suppose that 1 dollar is 6.91 yuan: ```javascript -let yuansPerDollar = 6.91; +let yuanPerDollar = 6.91; let dollarsCount = 50 * 1.25; // 62.5 -let yuansCount = dollarsCount * yuansPerDollar; // 431.875 +let yuanCount = dollarsCount * yuanPerDollar; // 431.875 -console.log(yuansCount); +console.log(yuanCount); ``` Now, let's merge our output with some text via concatenation: ```javascript -let yuansPerDollar = 6.91; +let yuanPerDollar = 6.91; let dollarsCount = 50 * 1.25; // 62.5 -let yuansCount = dollarsCount * yuansPerDollar; // 431.875 +let yuanCount = dollarsCount * yuanPerDollar; // 431.875 -console.log('The price is ' + yuansCount + ' yuans'); +console.log('The price is ' + yuanCount + ' yuan'); ```
-The price is 431.875 yuans
+The price is 431.875 yuan
 
Any variable can be part of any expression. During the computation, the variable's name is replaced with its value. diff --git a/modules/30-variables/23-constants/en/README.md b/modules/30-variables/23-constants/en/README.md index 5cefe9cd..12340ad1 100644 --- a/modules/30-variables/23-constants/en/README.md +++ b/modules/30-variables/23-constants/en/README.md @@ -33,7 +33,7 @@ const pi = 3.14; pi = 5; // TypeError: Assignment to constant variable. ``` -You may be wondering why we need it. Can't we just use variables? Even if we limit ourselves to variables, it won't change the fact that they will often play the role of constants. Moreover, it is possible to write JavaScript code idiomatically without using variables at all. Take a look at the example from [the actual Hexlet code](https://github.com/Hexlet/hexlet-exercise-kit/blob/main/import-documentation/index.js). You're unlikely to understand it at this stage, but try counting the number of constants and variables there are, you'll see that there's exactly one variable and a whole bunch of constants. +You may be wondering why we need it. Can't we just use variables? Even if we limit ourselves to variables, it won't change the fact that they will often play the role of constants. Moreover, it is possible to write JavaScript code idiomatically without using variables at all. Take a look at the example from [the actual Hexlet code](https://github.com/Hexlet/hexlet-exercise-kit/blob/main/import-documentation/index.js). You're unlikely to understand it at this stage, but try counting the number of constants and variables there are, you'll see that there's exactly one variable and a bunch of constants. Constants make it a lot easier to analyze; when we encounter a constant, it's obvious right away that its value always stays the same. With constants, we don't need to worry about when they were written. With variables, however, we can't be certain of their value and have to analyze all the code to figure out how they may have changed. diff --git a/modules/35-calling-functions/150-calling-functions-expression/en/README.md b/modules/35-calling-functions/150-calling-functions-expression/en/README.md index 39cef679..98ba6b62 100644 --- a/modules/35-calling-functions/150-calling-functions-expression/en/README.md +++ b/modules/35-calling-functions/150-calling-functions-expression/en/README.md @@ -16,7 +16,7 @@ const sum = 1 + 5; console.log(1 + 5); ``` -But not any code can be an expression. The definition of a variable is a statement, it can't be part of an expression and it will lead to an error: +But not any code can be an expression. The definition of a variable is a statement, it can't be part of an expression, and it will lead to an error: ```javascript // Pointless code that won't work diff --git a/modules/35-calling-functions/270-deterministic/en/README.md b/modules/35-calling-functions/270-deterministic/en/README.md index 95923b21..83c91466 100644 --- a/modules/35-calling-functions/270-deterministic/en/README.md +++ b/modules/35-calling-functions/270-deterministic/en/README.md @@ -1,5 +1,5 @@ -Regardless of the programming language, functions possess certain fundamental properties. Knowing these properties makes it easier to predict the behavior of functions, as well as their testing and their usage. These properties include determinacy. A function is deterministic when it returns the same result for the same input parameters. For example, a function counting the number of characters is deterministic: +Regardless of the programming language, functions possess certain fundamental properties. Knowing these properties makes it easier to predict the behavior of functions, as well as their testing and their usage. These properties include determinism. A function is deterministic when it returns the same result for the same input parameters. For example, a function counting the number of characters is deterministic: ```javascript import { length } from 'hexlet-basics/string'; @@ -19,4 +19,4 @@ Math.random(); // 0.09856613113197676 Math.random(); // 0.8839904367241888 ``` -So what use is knowing that to us? Determinacy seriously affects many different aspects. Deterministic functions are easy to work with, easy to optimize, and easy to test. If you can make a function deterministic, it's best to make it one. +So what use is knowing that to us? Determinism seriously affects many different aspects. Deterministic functions are easy to work with, easy to optimize, and easy to test. If you can make a function deterministic, it's best to make it one. diff --git a/modules/35-calling-functions/350-stdlib/en/README.md b/modules/35-calling-functions/350-stdlib/en/README.md index 03e0fe6e..35330d03 100644 --- a/modules/35-calling-functions/350-stdlib/en/README.md +++ b/modules/35-calling-functions/350-stdlib/en/README.md @@ -11,4 +11,4 @@ Here are some tips to learn about new features: The JavaScript standard library's structure has its peculiarities. Since the code can run in different environments, such as a server or a browser, the capabilities of the standard library are highly dependent on the use case. For example, you can't perform some server tasks in a browser. For server-side documentation, see https://nodejs.org. The server portions of the standard library are organized into modules, each module has its own page with full descriptions of all its functions. In particular, the module [fs](https://nodejs.org/api/fs.html) is required to work with the file system, its functions allow you to write and read files. -As for the browsers, there's not much stuff. For the most part, it's some basic functions built into the language. For example, the math [functions](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Math) we've seen before.. The rest of the features you can add via third-party libraries. +As for the browsers, there's not much stuff. For the most part, it's some basic functions built into the language. For example, the math [functions](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Math) we've seen before. The rest of the features you can add via third-party libraries. diff --git a/modules/38-properties/200-properties-methods/en/README.md b/modules/38-properties/200-properties-methods/en/README.md index f7ee09e1..ac581964 100644 --- a/modules/38-properties/200-properties-methods/en/README.md +++ b/modules/38-properties/200-properties-methods/en/README.md @@ -29,7 +29,7 @@ Why do we need methods? Why not just use functions? The situation with numbers i There are two reasons why it's done that way: -1. It's just always been like that. JavaScript was developed a little too quickly, so not everything was well thought out +1. It's just always been like that. JavaScript was developed a little too quickly, so not everything was well-thought-out 2. Not all functions are linked to a specific value. For example, `Math.min()`. This function finds the minimum of all numbers passed to it. It doesn't make sense to make this function a method of a particular number, like `(1).min()`. It has no connection to any particular number On the other hand, functions that work with a particular number should be implemented as methods for the sake of consistency. Such functions include calculating the modulus of a number. I.e., instead of `Math.abs(-10)`, it's more reasonable to have `(-10).abs()`. diff --git a/modules/40-define-functions/150-define-functions-return/en/README.md b/modules/40-define-functions/150-define-functions-return/en/README.md index 4b4f9863..9e588aaf 100644 --- a/modules/40-define-functions/150-define-functions-return/en/README.md +++ b/modules/40-define-functions/150-define-functions-return/en/README.md @@ -5,7 +5,7 @@ Functions in JavaScript become really useful when they start to return data rath const message = greetHexlet(); console.log(message); ``` -We assign a function output to the variable `message`. In order to make this code work, the function must use the `return` instruction inside of itself: +We assign a function output to the variable `message`. In order to make this code work, the function must use the `return` instruction inside itself: ```javascript const greetHexlet = () => { diff --git a/modules/45-logic/28-logical-negation/en/EXERCISE.md b/modules/45-logic/28-logical-negation/en/EXERCISE.md index 7237d1c3..92097e9c 100644 --- a/modules/45-logic/28-logical-negation/en/EXERCISE.md +++ b/modules/45-logic/28-logical-negation/en/EXERCISE.md @@ -1,5 +1,5 @@ -1. Write a function, `isPalindrome()`, to check if a word is a palindrome. A palindrome is a word that reads the same backwards as it does forwards. +1. Write a function, `isPalindrome()`, to check if a word is a palindrome. A palindrome is a word that reads the same backwards as it does forward. ```javascript isPalindrome('refer'); // true diff --git a/modules/45-logic/70-logical-expressions/en/README.md b/modules/45-logic/70-logical-expressions/en/README.md index 84a52259..28c15537 100644 --- a/modules/45-logic/70-logical-expressions/en/README.md +++ b/modules/45-logic/70-logical-expressions/en/README.md @@ -42,7 +42,7 @@ undefined || ''; // '' If `name` is given one of the falsy values, an empty string will be assigned to the `value` constant. In that case, in subsequent code, we will be able to treat `value` as a string. -But there is a potential bug. If `name` contains a falsy value and it's okay to assign values like `0`, `undefined`, `NaN` or `null` to the `value` constant, then the code above will get it wrong: +But there is a potential bug. If `name` contains a falsy value, and it's okay to assign values like `0`, `undefined`, `NaN` or `null` to the `value` constant, then the code above will get it wrong: ```javascript // Oops @@ -51,7 +51,7 @@ false || ''; // '' undefined || ''; // '' ``` -We covered the comparison operators `===` and `!==` in one of our lessons and we mentioned that JavaScript also has the operators `==` and `!=`, though you shouldn't use them. The very difference lies in the type conversion: +We covered the comparison operators `===` and `!==` in one of our lessons, and we mentioned that JavaScript also has the operators `==` and `!=`, though you shouldn't use them. The very difference lies in the type conversion: ```javascript console.log('' === false); // => false diff --git a/modules/48-conditionals/65-switch/en/README.md b/modules/48-conditionals/65-switch/en/README.md index c4e690a7..0580b04e 100644 --- a/modules/48-conditionals/65-switch/en/README.md +++ b/modules/48-conditionals/65-switch/en/README.md @@ -37,7 +37,7 @@ Switch is a rather advanced construct considering the number of elements it cons * The `case` and `default` constructs, where the behavior for different values of the variable is described. Each `case` corresponds to `if` in the example above. `default` is a special condition corresponding to the `else` branch in conditionals. Neither `else` nor `default` is necessary (but the linter will always [ask for it](https://eslint.org/docs/rules/default-case)) * `break` is needed to prevent it from "falling through". If `break` is omitted, then the program will continue to the next `case` statement after the required `case`, and carry on until the next `break` or the end of the *switch* -The curly brackets in `switch* don't specify a code block unlike elsewhere. Only the syntax shown above is acceptable. In other words, you can use `case` or `default` there. But inside each `case` (and `default`), the situations are different. You can execute any arbitrary code here: +The curly brackets in `switch` don't specify a code block unlike elsewhere. Only the syntax shown above is acceptable. In other words, you can use `case` or `default` there. But inside each `case` (and `default`), the situations are different. You can execute any arbitrary code here: ```javascript switch (count) { diff --git a/modules/50-loops/10-while/en/README.md b/modules/50-loops/10-while/en/README.md index 27fd9e0e..c0bc1d43 100644 --- a/modules/50-loops/10-while/en/README.md +++ b/modules/50-loops/10-while/en/README.md @@ -104,4 +104,4 @@ while (true) { } ``` -To sum up. When do we need loops and when can we do without them? It is physically impossible to do without loops when a problem-solving algorithm requires actions to be repeated, as in the example with the book, and the number of these actions is unpredictable. +To sum up. When do we need loops, and when can we do without them? It is physically impossible to do without loops when a problem-solving algorithm requires actions to be repeated, as in the example with the book, and the number of these actions is unpredictable. diff --git a/modules/50-loops/20-aggregation-numbers/en/README.md b/modules/50-loops/20-aggregation-numbers/en/README.md index 5666ebe0..c66099dd 100644 --- a/modules/50-loops/20-aggregation-numbers/en/README.md +++ b/modules/50-loops/20-aggregation-numbers/en/README.md @@ -68,6 +68,6 @@ sum = sum + 2; // ? It will result in `NaN`, i.e. not a number, in `sum`. It occurs due to an attempt to add `2` and `undefined`. So you need to have an initial value. Why is 0 chosen in the code above? Well, it is easy to check that all the other options would lead to the wrong result. If the initial value is 1, the sum will be 1 more than it should be. -In mathematics, there is a concept of an **identity element/neutral element**, an element for each type of operation. Its meaning is easy to grasp. An operation with this element doesn't change the operand. For addition, any number plus zero results in the number itself. The same goes for subtraction. Even concatenation has a neutral element, which is an empty string: `'' + 'one'` will be 'one'. +In mathematics, there is a concept of an **identity element/neutral element**, an element for each type of operation. Its meaning is easy to grasp. An operation with this element doesn't change the operand. In addition, any number plus zero results in the number itself. The same goes for subtraction. Even concatenation has a neutral element, which is an empty string: `'' + 'one'` will be 'one'. Self-check. What is the neutral element of a multiplication operation? diff --git a/modules/50-loops/26-conditions-inside-loops/en/README.md b/modules/50-loops/26-conditions-inside-loops/en/README.md index 71674633..9a8ea290 100644 --- a/modules/50-loops/26-conditions-inside-loops/en/README.md +++ b/modules/50-loops/26-conditions-inside-loops/en/README.md @@ -12,7 +12,7 @@ countChars('Sansa', 'y'); // 0 Before examining its contents, answer these questions: * Is this an aggregate operation? -* What will be the test condition for whether or not the character occurs? +* What will be the test condition for whether the character occurs? ```javascript const countChars = (str, char) => {