官术网_书友最值得收藏!

The OS module in require()

Once we have created and appended the greetings.txt file, we'll customize this greeting.txt file. To do this, we'll explore one more built-in module. We'll be using more than just appendFile in the future. We'll be exploring other methods. For this section, the real goal is to understand require(). The require() function lets us load in the module's functionality so that we can call it.

The second module that we'll be using is OS, and we can view it in the documentation. In the OS module, we'll use the method defined at the very bottom, os.userInfo([options]):

The os.userInfo([options]) method gets called and returns various information about the currently logged-in user, such as the username, and this is what we'll pull off:

Using the username that comes from the OS, we can customize the greeting.txt file so that instead of Hello world! it can say Hello Gary!.

To get started, we have to require OS. This means that we'll go back inside Atom. Now, just below where I created my fs constant, I'll create a new constant called os, setting it equal to require(); this gets called as a function and passes one argument, the module name, os, as shown here:

console.log('Starting app.');

const fs = require('fs');
const os = require('os');

fs.appendFile('greetings.txt', 'Hello world!');

From here, we can start calling methods available on the OS module, such as os.userInfo([optional]).

Let's make a new variable called user to store the result. The variable user will get set equal to os.userInfo, and we can call userInfo without any arguments:

console.log('Starting app.');

const fs = require('fs');
const os = require('os');

var user = os.userInfo();

fs.appendFile('greetings.txt', 'Hello world!');

Now, before we do anything with the fs.appendFile line, I'll comment it out and print the contents of the user variable using console.log:

console.log('Starting app.');

const fs = require('fs');
const os = require('os');

var user = os.userInfo();
console.log(user);
// fs.appendFile('greetings.txt', 'Hello world!');

This will let us explore exactly what we get back. Over in Terminal, we can rerun our program using the up arrow key and enter key, and right here in the following code, you see that we have an object with a few properties:

We have uid, gid, username, homedir, and shell. Depending on your OS, you'll not have all of these, but you should always have the username property. This is the one we care about.

This means that back inside Atom, we can use user.username inside of appendFile. I'll remove the console.log statement and uncomment our call to fs.appendFile:

console.log('Starting app.');

const fs = require('fs');
const os = require('os');

var user = os.userInfo();

fs.appendFile('greetings.txt', 'Hello world!');

Now, where we have world in the fs.appendFile, we'll swap it with user.username. There are two ways we can do this.

主站蜘蛛池模板: 工布江达县| 新竹市| 丘北县| 阳西县| 汤原县| 邯郸县| 四会市| 武乡县| 乐安县| 宣化县| 鄂州市| 康保县| 舒城县| 永丰县| 桃源县| 秀山| 灵璧县| 荔浦县| 河西区| 丰城市| 宝应县| 郧西县| 定陶县| 文登市| 唐河县| 平谷区| 天峻县| 泽州县| 常熟市| 潞西市| 邹城市| 青阳县| 二连浩特市| 武夷山市| 娄底市| 抚远县| 四平市| 三亚市| 黎川县| 手游| 波密县|