5.1什么是第三方模块

```
别人写好的,具有特定功能的,我们能直接使用的模块即第三方模块,由于第三方模块通常都是由多个文件组成并且被放置在一个文件夹中,所以又名包。
```

第三方模块有两种存在形式

  • 以js文件的形式存在,提供实现项目具体功能的API接口
  • 以命令行工具形式存在,辅助项目开发

5.2获取第三方模块

```
npmjs.com 第三方模块的存储和分发仓库
npm(node package manager): node 的第三方模块管理工具
```

  • 下载:npm install 模块名称
  • 卸载:npm uninstall package 模块名称

5.3全局安装与本地安装

  • 命令行工具:全局安装
  • 库文件:本地安装

5.4第三方模块 nodemon

```
nodemon是一个命令行工具,用以辅助项目开发
在Node.js中,每次修改文件都要在命令行工具中重新执行该文件,非常繁琐
```

使用步骤

```
1.使用npm install nodemon -g 下载它(mac 需要加前缀sudo)
2.在命令行工具中用nodemon 命令替代node 命令执行文件
```

5.5第三方模块 nrm

```
nrm(node registry manager): npm 下载地址切换工具
npm 默认的下载地址是国外,国内下载速度慢
```

使用步骤

```
1.使用npm install nrm -g 下载它
2.查询可用下载地址列表 nrm ls
3.切换npm 下载地址 nrm use 下载地址名称
```

5.6第三方模块 Gulp

```
基于node平台开发的前端构建工具
也就是将机械化操作编写成任务,想要执行机械化操作时执行一个命令行命令任务就能自动执行了
```

Gulp可以做什么?

  • 项目上线,html,css,js文件压缩合并
  • 语法转换(es6,less...)
  • 公共文件抽离
  • 修改文件浏览器自动刷新

Gulp中提供的方法

  • gulp.src():获取任务要处理的文件
  • gulp.dest():输出文件
  • gulp.task('任务名字',callback):建立gulp任务
  • gulp.watch():监控文件的变化

```
const gulp = require('gulp');
//使用gulp.task()方法建立任务
gulp.task('first',()=>{
//获取要处理的文件
gulp.src('./src/css/base.css')
//将处理后的文件输出到dist目录
.pipe(gulp.dest('./dist/css'));
});
```

使用步骤

```
1.使用npm install gulp 下载gulp库文件
2.在项目根目录下建立gulpfile.js文件
3.重构项目的文件夹结构src目录放置源代码文件dist目录放置构建后文件
4.在gulpfile.js文件中编写任务
5.在命令行工具中执行gulp任务
```

安装指定的Gulp版本

```
npm install gulp@3.9.1
```

安装Gulp命令行工具

```
npm install gulp-cli -g
clear清屏
gulp first执行first任务
```

Gulp插件

  • gulp-htmlmin:html文件压缩
  • gulp-csso:压缩css
  • gulp-babel:javaScript语法转化
  • gulp-less:less语法转化
  • gulp-uglify:压缩混淆JavaScript
  • gulp-file-include:公共文件包含
  • browsersync浏览器实时同步

node_modules文件夹的问题

```
1.文件夹以及文件过多过碎,当我们将项目整体拷贝给别人的时候,传输速度会很慢很慢
2.复杂的模块依赖关系需要被记录,确保模块的版本和当前保持一致,否则会导致当前项目运行报错
```

package.json文件的作用

```
1.项目描述文件,记录了当前项目信息,例如项目名称,版本,作者,github地址,当前项目依赖了哪些第三方模块等
2.使用npm init -y命令生成(不填写任何信息,都用默认值)
3.package.json文件中'scripts'存储的都是命令的别名
//基本使用
{
"script":{
"build":"nodemon app.js"
}
}
//一般情况下执行:nodemon app.js
//设置后:npm run build
```

项目依赖

```
1.在项目的开发阶段和线上运营阶段,都需要依赖的第三方包,称为项目依赖
2.使用npm install 包名命令下载的文件会默认被添加到package.json文件的dependencies字段中
3.如果只想安装项目依赖,命令行使用 npm install --production
```

开发依赖

```
1.在项目的开发阶段需要依赖,线上运营阶段不需要依赖的第三方包,称为开发依赖
2.使用npm install 包名 --save-dev 命令将包添加到package.json文件的devDependencies字段中
```

package-lock.json文件的作用

```
1.锁定包的版本,确保再次下载时不会因为包版本不同而产生问题
2.加快下载速度,因为该文件中已经记录了项目所依赖第三方包的树状结构和包的下载地址,重新安装时只需下载即可,不需要做额外的工作
```
```
//html任务
//1.html文件中代码的压缩操作
//2.抽取html文件中的公共代码
npm install gulp-htmlmin 下载gulp插件
npm install gulp-file-include 下载gulp插件
npm install gulp-less 下载gulp插件
npm install gulp-csso 下载gulp插件
npm install gulp-babel @babel/core @babel/preset-env 下载gulp插件
npm install gulp-uglify 下载gulp插件

//引用gulp插件

const gulp = require('gulp');

const htmlmin = require('gulp-htmlmin');

const fileinclude = require('gulp-file-include');

const less = require('gulp-less');

const csso = require('gulp-csso');

const babel = require('gulp-babel');

const uglify = require('gulp-uglify');

gulp.task('htmlmin',()=>{

gulp.src('./src/*.html')

.pipe(fileinclude())

.pipe(htmlmin({collapseWhitespace:true}))

.pipe(gulp.dest('dist'));

});

//命令行执行

gulp htmlmin

//引回公共代码

//@@include('路径‘)

//css任务

//1.less语法转换

//2.css代码压缩

gulp.task('cssmin',()=>{

//选择css目录下的所有less文件以及css文件

gulp.src(['./src/css/.less','./src/css/.css'])

//将less语法转换为css语法

.pipe(less())

//将css代码进行压缩

.pipe(csso())

//将处理的结果进行输出

.pipe(gulp.dest('dist/css'))

});

//命令行执行

gulp cssmin

//js任务

//1.es6代码转换

//2.代码压缩

gulp.task('jsmin',()=>{

gulp.src('/src/js/*.js')

.pipe(babel({

//它可以判断当前代码的运行环境 将代码转换为当前运行环境所支持的代码

presets:['@babel/env']

}))

.pipe(uglify())

.pipe(gulp.dest('dist/js'))

})

//命令行执行

gulp jsmin

//复制文件夹

gulp.task('copy',()=>{

gulp.src('./src/images/')

.pipe(gulp.dest('dist/images'));

gulp.src('./src/lib/
')

.pipe(gulp.dest('dist/lib'));

})

//命令行执行

gulp copy

//构建任务

gulp.task('default',['htmlmin','cssmin','jsmin','copy']);

//命令行执行

gulp default/gulp

05-Node.js学习笔记-第三方模块的更多相关文章

  1. 04 Node.js学习笔记之模块的加载

    A文件代码: //1.require是一个方法,它的作用就是用来加载模块的 console.log("执行 B ") require('./b.js'); console.log( ...

  2. 05 Node.js学习笔记之发送文件数据

    这章学习在NodeJs中如何将Html文件发送到客户端上,以及定义Content-Type内容类型 //1.载入http和fs模块 var http=require("http") ...

  3. Node.js学习笔记(2):基本模块

    Node.js学习笔记(2):基本模块 模块 引入模块 为了编写可维护的代码,我们把很多函数分组,分别放到不同的文件里,这样,每个文件包含的代码就相对较少,很多编程语言都采用这种组织代码的方式.在No ...

  4. 一点感悟:《Node.js学习笔记》star数突破1000+

    写作背景 笔者前年开始撰写的<Node.js学习笔记> github star 数突破了1000,算是个里程碑吧. 从第一次提交(2016.11.03)到现在,1年半过去了.突然有些感慨, ...

  5. Node.js学习笔记(3):NPM简明教程

    Node.js学习笔记(3):NPM简明教程 NPM常用操作 更新NPM版本 npm install npm -g -g,表示全局安装.我们可以指定更新版本,只需要在后面填上@版本号即可,也可以输入@ ...

  6. 系列文章--Node.js学习笔记系列

    Node.js学习笔记系列总索引 Nodejs学习笔记(一)--- 简介及安装Node.js开发环境 Nodejs学习笔记(二)--- 事件模块 Nodejs学习笔记(三)--- 模块 Nodejs学 ...

  7. Node.js学习笔记(1):Node.js快速开始

    Node.js学习笔记(1):Node.js快速开始 Node.js的安装 下载 官方网址:https://nodejs.org/en/ 说明: 在Windows上安装时务必选择全部组件,包括勾选Ad ...

  8. Node.js学习笔记(4):Yarn简明教程

    Node.js学习笔记(4):Yarn简明教程. 引入Yarn NPM是常用的包管理工具,现在我们引入是新一代的包管理工具Yarn.其具有快速.安全.可靠的特点. 安装方式 使用npm工具安装yarn ...

  9. Node.js学习笔记(二):模块

    模块是 Node.js 应用程序的基本组成部分,文件和模块是一一对应的.一个 Node.js 文件就是一个模块,这个文件可能是 JavaScript 代码.JSON 或者编译过的 C/C++ 扩展. ...

随机推荐

  1. WebGPU学习(五): 现代图形API技术要点和WebGPU支持情况调研

    大家好,本文整理了现代图形API的技术要点,重点研究了并行和GPU Driven Render Pipeline相关的知识点,调查了WebGPU的相关支持情况. 另外,本文对实时光线追踪也进行了简要的 ...

  2. solr索引基本原理

    solr是一个全局检索引擎,能够快速地从大量的文本数据中选出你所需要的数据,而你只需要提供相应的关键词进行检索.solr的高效率查询靠的是底层强大的索引库,所以solr最关键的技术也是其底层的索引设计 ...

  3. 深入理解 Java 反射和动态代理

  4. BIOS安全设置

    1.开机按F2进入BIOS 2.进入 Security 界面 3.Set user password 用户密码 开机密码 设置为123456 4.Set supervisor password 进BI ...

  5. 学习了JsonSchema,我自定义了一个校验代码

    JsonSchema 使用fastjsonschema来校验数据 # 导入验证器 import json import fastjsonschema # 读取schema with open('../ ...

  6. 1篇文章搞清楚8种JVM内存溢出(OOM)的原因和解决方法

    前言 撸Java的同学,多多少少会碰到内存溢出(OOM)的场景,但造成OOM的原因却是多种多样. 堆溢出 这种场景最为常见,报错信息: java.lang.OutOfMemoryError: Java ...

  7. spring data jpa 操作pipelinedb 的continuous view 与stream

    一. 由于pipelinedb是postgreSQL的扩展,因此相关依赖于配置都合集成postgreSQL是一样的. springboot + spring data jpa + postgreSQL ...

  8. 2020年值得你去试试的10个React开发工具

    本文由葡萄城技术团队翻译并首发 转载请注明出处:葡萄城官网,葡萄城为开发者提供专业的开发工具.解决方案和服务,赋能开发者. JavaScript每天都在出现大量的框架和工具,而React是除了上次我们 ...

  9. 更新Preloader和uboot

    在SoCEDS环境下编译和更新preloader和uboot程序的方法   前面有介绍preloader在HPS boot过程中的的作用,接下来讲述下用户在SoCEDS环境下改如何编译preloade ...

  10. LeetCode刷题总结-栈、链表、堆和队列篇

    本文介绍LeetCode上有关栈.链表.堆和队列相关的算法题的考点,推荐刷题20道.具体考点分类如下图: 一.栈 1.数学问题 题号:85. 最大矩形,难度困难 题号:224. 基本计算器,难度困难 ...