Skip to content
Advertisement

Get data from fs.readFile [duplicate]

JavaScript

Logs undefined, why?

Advertisement

Answer

To elaborate on what @Raynos said, the function you have defined is an asynchronous callback. It doesn’t execute right away, rather it executes when the file loading has completed. When you call readFile, control is returned immediately and the next line of code is executed. So when you call console.log, your callback has not yet been invoked, and this content has not yet been set. Welcome to asynchronous programming.

Example approaches

JavaScript

Or better yet, as Raynos example shows, wrap your call in a function and pass in your own callbacks. (Apparently this is better practice) I think getting into the habit of wrapping your async calls in function that takes a callback will save you a lot of trouble and messy code.

JavaScript
User contributions licensed under: CC BY-SA
4 People found this is helpful
Advertisement