There are currently no frequently asked questions associated with this exercise – that’s where you come in! You can contribute to this section by offering your own questions, answers, or clarifications on this exercise. Ask or answer a question by clicking reply () below.
If you’ve had an “aha” moment about the concepts, formatting, syntax, or anything else with this exercise, consider sharing those insights! Teaching others and answering their questions is one of the best ways to learn and stay sharp.
Join the Discussion. Help a fellow learner on their journey.
Ask or answer a question about this exercise by clicking reply () below!
Agree with a comment or answer? Like () to up-vote the contribution!
It is requiring in “fs”, but I can’t find where that is coming from. My understanding was that require() would import a module from another file. Is that correct? If so, I’m unclear of how this works in this instance.
This line reads a file file.txt in the working directory (./) in the unicode. The third argument specifies a callback function, the function to be executed once reading the file is done.
if (err) throw err;
If there is an error while reading the file, the callback function’s first argument err will be true. So this line will be executed to throw an error (an error message will be printed in the console). And the rest of the code will be ignored.
let firstSentence = data;
The callback function’s second argument data will be the file content if reading the file is successfully done. We store the file content as the variable called firstSentence.
This is the same as the first line except for the file: it will read file2.txt.
if (err) throw err;
This is the same as the second line. If reading file2.txt fails, an error message will be shown in the console. And the rest of the code will be ignored.
let secondSentence = data;
This line stores the file2.txt’s content as the variable secondSentence.
console.log(firstSentence, secondSentence)
The file content from file1.txt and file2.txt will be shown in the console.
In the first line, firstSentence is declared outside of the promise object chain and then assigned a value within the object chain. Would it not be cleaner to declare the variable and assign it a value within the object, like in the first part of the code?
But more importantly, I don’t understand how the promise is created. Codecademy teaches us that a new Promise must be created first and that it can only contain an executor function as parameter. But in this example, promisifiedReadfile shows up out of nowhere with both success and failure parameters. How does JS understand that this is a promise, other than it being followed by .then?
Why doesn’t this result in an error? And if this is indeed a proper method of creating a new promise, why was this not taught in the the earlier lessons and exercises?
I look at this part of the code and it seems completely wrong to me, as it does not follow what we’ve learned so far.
I think that the firstSentence variable is declared outside the local scope of the first .then() — in global scope — because otherwise we wouldn’t be able to access it when logging both sentences to the console in the second .then() .
At the top of app.js , promisifiedReadfile is imported as a module from the file with the same name, using the following code:
Unfortunately, when this exercise loads, promisifiedReadfile.js is hidden. To view the file, click the file icon in the top left hand corner of the code-editor where you will find a list of all four files used in this exercise. Click on promisifiedReadfile.js and you will then be able to view it in the code-editor. Here you will find the function which constructs the promise and contains the executor function, both of which you quite rightly expected to see…
fs is actually a node module. fs stands for File System, and it allows us to work with files. As you saw in the lesson, we used the fs module to read the text in the file
The instructions about “you’ll be given… a bash terminal to execute your code.” are excellent.
I wonder whether all this course would gain in quality if these instructions were moved up to the lesson 5 of chapter “Transpilation”. At that lesson, the learner was brutally dropped into using the terminal without much explanations.
Answering your first question: This is arrow function syntax. If you only want to return something in the function body (i.e., withing the braces { } ), then you can just omit the braces and the return keyword. Review the JavaScript Beginner course on arrow.
Hi, I was looking at this introduction and I noticed that the result of “promisifiedReadfile(‘./file.txt’, ‘utf-8’)” is assigned to the variable “firstSentence”. If you check the type of “firstSentence” it says that it is a string but I believe that “promisifiedReadfile” returns a Promise. Can someone explain it to me?
async function readFiles() {
let firstSentence = await promisifiedReadfile(‘./file.txt’, ‘utf-8’);
console.log(typeof firstSentence);
let secondSentence = await promisifiedReadfile(‘./file2.txt’, ‘utf-8’);
console.log(typeof firstSentence);
console.log(firstSentence, secondSentence);
}