美文网首页
【融职培训】Web前端学习 第5章 node基础教程4 Node

【融职培训】Web前端学习 第5章 node基础教程4 Node

作者: lmonkey_01 | 来源:发表于2020-06-19 15:39 被阅读0次

一、模块化开发

之前我们做过一个练习,使用node运行一个js文件。但是在实际项目开发中,不可能将全部代码都写在一个文件中。node为我们提供了模块化的语法,每一个js文件都可以当做一个模块:

require() 引入一个外部模块

module.exports 暴露模块接口

现在我们实现一个加法计算的功能,在一个add.js文件中编写一个加法函数,然后用module.exports暴露这个方法,然以在创建一个入口文件main.js引入这个加法函数,并通过加法函数计算结果。

示例代码如下所示:

1// add.js定义一个模块,处理加法和减法 2function add(a,b){ 3returna + b; 4} 5module.exports = add; 6 7// main.js引入外部模块,使用加法和减法函数 8const add = require("./add"); 9let result = add(10,20);10console.log(result)

可以看到在命令行中输出运算结果30。

ES2015的模块化语法

这里需要补充一个知识点,在ES2015中的模块化语法与node的模块化语法略有差异,如下所示

import 引入外部模块

export 暴露模块接口

在vue的课程中,我们会使用到ES2015的模块化语法,这里不做深入讨论。

外部模块

上面我们已经学习了使用require可以引入一个自定义的外部模块,其实其实引入的外部模块有三种情况:

核心模块:核心模块是node自带的模块,可以在require引入后直接使用。

自定义模块:自定义模块是我们自己编写的,上面模块化的例子中,add.js文件就是一个自定义模块。引入自定义模块需要些完整的路径。

第三方模块:使用npm下载的模块是第三方模块,下载完成后可以使用require直接引入

本章后续内容我们会讲解第三方模块的使用,本节只讲解常用的核心模块。

二、核心模块

fs

fs模块是node的文件系统模块,通过此模块的readFile方法可以读取文件,我们新建一个readFile.js文件,然后在其目录同级创建一个txt文件,内容为hello node,然后编辑readFile.js文件,代码如下所示:

1const fs = require("fs");2fs.readFile("hello.txt", (err,data) => {3if(err){4        console.log(err);5    }6    console.log(data.toString());7})

然后在此目录下执行

node readFile.js

在示例代码中,fs的readFile方法有两个参数

第一个参数是读取文件的地址

第二个参数是一个回调函数

如果读取文件失败,回调函数的第一个参数err会显示错误信息,如果读取文件成功,则err为null。

data是一个buffer类型,我们暂时不用理解,只要知道data.toString可以把buffer类型转换成字符串即可。

程序运行最终结果会在命令行中输出hello node

本节我们主要的学习目标是了解如何使用核心模块,所以关于fs模块的更多使用方法,本节不再展开描述。

path

path 模块提供了一些用于处理文件路径的小工具,例如我们可以用path的join方法链接两个路径,实例代码如下所示。

1const path = require("path");23let domain = "https://www.eduwork.cn/"4let url = "docs";5let id = "22";67let address = path.join(domain,url,id);89console.log(address);

我们首先引入path模块,然后定义三个变量,使用path的join方法传入这三个变量,输出的结果是三个变量链接在一起的路径

http:\www.eduwork.cn\docs\22

http

http模块是可以用来创建web服务器,我们会在下节内容中进一步讲解。

三、课后练习

定义一个可以完成四则运算的node模块。

用fs模块打开d盘test目录下的index.html文件。(自己手动创建缺失的文件和目录)

【融职教育】在工作中学习,在学习中工作

相关文章

网友评论

      本文标题:【融职培训】Web前端学习 第5章 node基础教程4 Node

      本文链接:https://www.haomeiwen.com/subject/kcavxktx.html