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

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.

主站蜘蛛池模板: 阿巴嘎旗| 韩城市| 马鞍山市| 吉林省| 洛南县| 建宁县| 隆德县| 安义县| 筠连县| 伊金霍洛旗| 平陆县| 溧水县| 瓦房店市| 任丘市| 揭西县| 敦煌市| 丹东市| 那坡县| 布拖县| 镇坪县| 大关县| 会同县| 东莞市| 万安县| 金华市| 台南县| 陆良县| 兴化市| 中宁县| 依兰县| 岐山县| 绵竹市| 屏东县| 汾阳市| 萝北县| 双峰县| 神木县| 阜阳市| 洞口县| 安泽县| 大冶市|