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

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.

主站蜘蛛池模板: 临武县| 临夏市| 边坝县| 淮南市| 合肥市| 东阳市| 丽江市| 四川省| 汤原县| 新营市| 安岳县| 浏阳市| 鸡西市| 锡林浩特市| 大城县| 苍溪县| 长春市| 金沙县| 武邑县| 洪洞县| 洪江市| 鲁山县| 贵德县| 丹阳市| 荆州市| 亚东县| 松桃| 阳城县| 萝北县| 武夷山市| 康乐县| 罗甸县| 延川县| 和顺县| 中宁县| 西宁市| 尉犁县| 刚察县| 大埔县| 垦利县| 霍邱县|