前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Web前端学习 第5章 node基础教程4 Node基础

Web前端学习 第5章 node基础教程4 Node基础

原创
作者头像
学习猿地
修改2020-06-19 17:48:51
3190
修改2020-06-19 17:48:51
举报
文章被收录于专栏:学习猿地学习猿地学习猿地

一、模块化开发

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

  • require() 引入一个外部模块
  • module.exports 暴露模块接口

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

示例代码如下所示:

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

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

ES2015的模块化语法

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

  • import 引入外部模块
  • export 暴露模块接口

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

外部模块

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

  1. 核心模块:核心模块是node自带的模块,可以在require引入后直接使用。
  2. 自定义模块:自定义模块是我们自己编写的,上面模块化的例子中,add.js文件就是一个自定义模块。引入自定义模块需要些完整的路径。
  3. 第三方模块:使用npm下载的模块是第三方模块,下载完成后可以使用require直接引入

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

二、核心模块

fs

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

1 const fs = require("fs");
2 fs.readFile("hello.txt", (err,data) => {
3     if(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方法链接两个路径,实例代码如下所示。

1 const path = require("path");
2 
3 let domain = "https://www.eduwork.cn/"
4 let url = "docs";
5 let id = "22";
6 
7 let address = path.join(domain,url,id);
8 
9 console.log(address);

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

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

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

三、课后练习

  1. 定义一个可以完成四则运算的node模块。
  2. 用fs模块打开d盘test目录下的index.html文件。(自己手动创建缺失的文件和目录)

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 一、模块化开发
    • ES2015的模块化语法
      • 外部模块
      • 二、核心模块
        • fs
          • path
            • http
            • 三、课后练习
            领券
            问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档