这里我们学习nodejs的一些关键和基础的内容
npm是什么
-
相信各位大佬都知道npm这个东西。npm 其实又叫 node package manager,翻译过来就是node的包管理工具。它的但是解决了很实际的一些东西。
- 如果有早期做前端的人,如果用一个库,比如jQuery,就得去它的官网下载它的js文件,并且版本也比较难维护,有些特定版本官网还找不到。
- 现在有npm就可以很好的解决我们这些实际的问题。
假设你想下载一个jQuery来使用,有npm我们可以这样做,直接在控制台输入npm i jquery
你会发现文件夹中多了一个node_modules文件夹,文件夹内就有一个jquery的文件夹。 - 如果想指定版本,那么可以这样
npm i jquery@1.11.1
。怎么样是不是比你去官网找再下会快很多啊。
简单讲npm就是一个包维护的一个工具,常用的命令就那么几个,没什么内涵的东西在里面在这列举一些常用的npm命令,都不用记,你用到就记住了。
在项目中初始化一个 package.json 文件
凡是使用 npm 来管理的项目都会有这么一个文件
npm init
# 跳过向导,快速生成 package.json 文件
# 简写是 -y
npm init --yes
# 一次性安装 dependencies 中所有的依赖项
# 简写是 npm i
npm install
# 安装指定的包,可以简写为 npm i 包名
# npm 5 以前只下载,不会保存依赖信息,如果需要保存,则需要加上 `--save` 选项
# npm 5 以后就可以省略 --save 选项了
npm install 包名
# 一次性安装多个指定包
npm install 包名 包名 包名 ...
# 安装指定版本的包
npm install 包名@版本号
# npm list命令以树型结构列出当前项目安装的所有模块,以及它们依赖的模块。
npm list
# 加上global参数,会列出全局安装的模块
npm list -global
# npm list命令也可以列出单个模块
npm list 包名
# 安装全局包
npm install --global 包名
# 更新本地安装的模块
# 它会先到远程仓库查询最新版本,然后查询本地版本。如果本地版本不存在,或者远程版本较新,就会安装
npm update [package name]
# 升级全局安装的模块
npm update -global [package name]
# 卸载指定的包
npm uninstall 包名
# 查看包信息
# view 别名:v、info、show
npm view 包名
# 查看使用帮助
npm help
# 查看某个命令的使用帮助
# 例如我忘记了 uninstall 命令的简写了,这个时候,可以输入 `npm uninstall --help` 来查看使用帮助
npm 命令 --help
tips:npm 5 以后就可以省略 --save 选项,自动会给你的package.json中添加包信息了。
- 还有个特殊的假设你想升级你的npm,你可以这样
npm i npm
自己升级自己。 - -global/-g表示的是全局安装,有些东西可以全局安装,比如
nodemon eslint
。全局安装的包不会在node_modules内。
这里看起来命令很多很长,其实很多都有简写比如:
install/i
、-global/-g
、uninstall/un
。
- 解决npm下载慢问题
淘宝有npm官网的同步镜像,我们可以使用淘宝的镜像地址。淘宝镜像:https://npm.taobao.org/
+ 第一种方法:每次使用npm时指定从何处下载包。写法如下:
shell npm i jquery --registry=https://registry.npm.taobao.org
* 但是这样每次都要手动加--registry=https://registry.npm.taobao.org
非常麻烦
+ 第二种方法:直接使用https://registry.npm.taobao.org为我们的默认地址
```shell
# 配置到淘宝
npm config set registry https://registry.npm.taobao.org
# 查看 registry 是否配置正确
npm config list
```
* 这样你在使用`npm`的时候,默认就会去淘宝上下载包了。
+ 第三种方法:全局安装`cnmp`,然后用`cnmp`去代替`npm`。
```shell
# 全局安装cnpm
npm i cnpm -g
#下次使用
cnpm i
```
采用这三种方式都可以解决npm慢的问题。个人正在使用第二种方式,感觉不错。
- package.json和package-lock.json文件的解读
- package.json文件是记录你项目的一些基本信息。
- 当没有时可以使用
npm init
来初始化这个文件,填写的都是一些基本信息。项目名、描述等等。 - 你也可以不填写这些信息,快速生成该文件可以像这样
npm init -y
- 当没有时可以使用
- packages.json中的
scripts
这表示你的执行脚本,你可以像这样
"scripts": { "start": "node ./app.js" },
-
在这项目的命令行中我输入
npm start
实际上执行的是node ./app.js
。这样可以把复杂的启动脚本简单化。 -
packages.json中的main。这个相当于入口,比如你引用了
bootstrap
这个库。当var bs = require('bootstrap');
这条语句执行时,它会这样先找node_modules
这个文件夹,当前目录找不到就向上一级目录找,直到到找到这个node_modules
这个文件夹,它就在文件夹内找bootstrap
这个文件夹,找到后就到里面找package.json这个文件,没找到则找index.js。两个都没找到就报错。找到package.json就在文件内找main
,找到后根据main的值找到文件执行。找到index.js则执行这个文件。- 说了这么多,其实main主要是指定入口的文件。
-
packages.json中dependencies表示你这个项目用到的包,有可能它会像这样
"dependencies": { "bootstrap": "^4.1.3", }
- 这表示这个项目使用了bootstrap,并且版本4.1.3以上,^表示是以上的意思,相当于以上都行。
- 这样就存在一个问题,假设我这个项目就依赖于某版本的库那这样的维护会相对麻烦
npm i
是下载最新的包。所以出现了package-lock.json。
- 这样就存在一个问题,假设我这个项目就依赖于某版本的库那这样的维护会相对麻烦
- package.json文件是记录你项目的一些基本信息。
- package-lock.json
- 其实package-lock.json主要是用来记录包的版本,和提升
npm i
的性能。是npm 5 之后才出现的。- 有这个文件之后库的版本能得到维护,你再次使用
npm i
时版本还是以前的版本。 - 并且当你没有node_moudles这个文件夹时,使用
npm i
的速度会比较快。原因是npm只要读取package-lock.json这个文件就行了,文件中有包的下载地址和版本会加快下载速度。
- 有这个文件之后库的版本能得到维护,你再次使用
- 其实package-lock.json主要是用来记录包的版本,和提升
npm官网:https://www.npmjs.com/ 查找包,和包简单的使用非常有用。
初识node之文件操作
- fs模块异步同步操作文件
+ fs是系统提供的核心模块,提供了`readFile()`和`readFileSync()`,同步和异步读取文件。
* 同步会阻塞程序的执行,所以大部分情况推荐使用异步操作,特殊情况除外。
* 异步操作往往通过回调函数来获取操作的结果。
+ fs的常用api
> 更多可以去node官网查看,链接:http://nodejs.cn/api/fs.html
Api | 作用 | 注意点 |
---|---|---|
fs.appendFile(file, data, callback) | 向文件中追加内容 | |
fs.copyFile(src, callback) | 复制文件 | |
fs.mkdir(path, callback) | 创建文件夹 | |
fs.readDir(path, callback) | 读取文件夹列表 | |
fs.rmdir(path, callback) | 删除文件夹 | 只能删除空文件夹 |
fs.unlink(path, callback) | 删除文件 | |
fs.readFile(path, callback) | 读取文件内容 | |
fs.writeFile(path, callback) | 写出内容到文件 |
- fs的回调函数一般第一个参数为错误对象
err
,err
有值说明出错了,err
为null说明比较顺利。大概相当于这样:
fs.readFile('./index.html', 'utf8', function (err, data) {
if (err) {
throw err;
}
// do something
console.log(data);
})
- 基本的用法大概就是这样的,这里要注意的是
path
,为绝对路径会比较好,因为node
命令是依赖控制台的路径的,所以当你去另一个目录输入相对路径执行时就会报错。 - 例如这样:
E:> node index.js
是正常的,然而当你这样D:> node E:
就会报错找不到文件。
- path模块的用法
-
path模块的常用的方法
-
join(...agrs)
方法,很简单用户两个地址间的拼接,你可能见过这样的代码
fs.readFile(path.join(__dirName,'../index.html'),(err, data) => { if(err) throw err; })
这里就是将相对路径改成了绝对路径,这样就不会出现因为控制台地址的改变而读取不到文件了。
- path还有很多方法,你可以只记住
path.parse(path)
这一个。用的时候打印看一下,然后取你想要的。用法如下:
返回的对象有以下属性:
dir <string>
root <string>
base <string>
name <string>
ext <string>
例如在Windows系统上:
javascript path.parse('C:\\path\\dir\\file.txt'); // 返回: // { root: 'C:\\', // dir: 'C:\\path\\dir', // base: 'file.txt', // ext: '.txt', // name: 'file' }
在其他系统上
javascript path.parse('/home/user/dir/file.txt'); // 返回: // { root: '/', // dir: '/home/user/dir', // base: 'file.txt', // ext: '.txt', // name: 'file' }
-
-
很简单的nodejs,但是要学的灵活贯通还是非常的难,nodejs中有很多npm包,我曾经遇到一个人他每天坚持看10个npm包源码,但是以这个速度都要看非常之久。贵在坚持。加油!
下一个文章开始带来一系列干货。
网友评论