NPM简介

NPM

NPM(Node Package Manager)是Node.js的包管理工具,用于管理和分享JavaScript代码库。它是世界上最大的开源库生态系统之一。

安装node.js

这里的安装不做详细赘述,你只需要访问官方的网站,下载好安装包,然后进行安装就好了,相信这你一定能解决;

  • 如何验证你的node环境有没有安装好呢?
js 复制代码
node -v

如果输入上面返回版本号,说明你就安装成功了;

NPM的使用

  • 一般呢,我们会使用npm init去初始化node.js项目
  • 之后叫我们输入包名,这里使用默认的,后面的我们也全部默认,之后我们的当前目录就会生成一个package.json

这里node.js文件生成了所有关于这个项目的配置文件;

  • 我们也可以尝试安装一下其他的包,比如之前学习地图类demo的leaflet
js 复制代码
//国内使用npm install非常的慢,可以切换国内源
npm config set registry https://registry.npmmirror.com
//然后再安装leaflet会很快
npm config set registry https://registry.npmmirror.com
  • 安装成功后会发现package.json会多出一个字段,并且项目文件夹中会多出一个node_modules文件,里面包含leaflet的JavaScript代码库
  • 这里我们只是演示一下如何安装,并不去实际的使用他, 这里我们安装一个lodash-es ,注意我们需要安装ES版本,以便于我们去ES6模块的方式去使用它
js 复制代码
npm i lodash-es 

lodash-es 是 Lodash 库的 ES6 模块版本,它提供了一系列实用的工具函数,用于简化 JavaScript 编程的常见任务,如数组操作、对象操作、函数操作等。

  • 我们能看到它里面包含了很多很多的方法
  • 这里我们简单的使用它的模块,cloneDeep,这个是用于深度克隆对象或数组的方法
js 复制代码
import cloneDeep from './node_modules/lodash-es/cloneDeep.js';
const state = {
  cart: [
    { product: '面包', quantity: 5 },
    { product: '香蕉', quantity: 10 },
  ],
  user: { loggedIn: true },
};
const stateClone = Object.assign({}, state);
console.log(stateClone);
  • 我们简单的原数据也会副本也会立马生效
js 复制代码
import cloneDeep from './node_modules/lodash-es/cloneDeep.js';
const state = {
  cart: [
    { product: '面包', quantity: 5 },
    { product: '香蕉', quantity: 10 },
  ],
  user: { loggedIn: true },
};
const stateClone = Object.assign({}, state);
console.log(stateClone);

我们可以简单调用这个函数就可以直接实现对象或数组的深度克隆,如果自己去实现深度克隆,需要不小的代码量,以及需要自己去测试或者考虑其他的方面;

package.json非常重要

想象一个,一个中型的项目中,你需要将你的代码转交给其他人;如果你将所有的依赖都打包发给它,这可能会特别特别慢;所以通过package.json就能很简单的看出项目依赖哪些从而从npm中获取它,因为你也是从npm安装它,所以这很简单;

如果你的依赖包丢失,npm也可以帮助你快速的找回你所需要的所有的依赖

  • 这里将node_modules删除
  • 这时项目肯定是无法运行的,我们可以输入npm -i来安装你所需的依赖
相关推荐
pixle029 分钟前
Vue3 Echarts 3D饼图(3D环形图)实现讲解附带源码
前端·3d·echarts
麻芝汤圆1 小时前
MapReduce 入门实战:WordCount 程序
大数据·前端·javascript·ajax·spark·mapreduce
juruiyuan1113 小时前
FFmpeg3.4 libavcodec协议框架增加新的decode协议
前端
Vone_663 小时前
node.js 邮箱验证服务器搭建
运维·服务器·node.js
Peter 谭3 小时前
React Hooks 实现原理深度解析:从基础到源码级理解
前端·javascript·react.js·前端框架·ecmascript
程序员拂雨4 小时前
HTTP和HTTPS模块
http·https·node.js
LuckyLay5 小时前
React百日学习计划——Deepseek版
前端·学习·react.js
gxn_mmf5 小时前
典籍知识问答重新生成和消息修改Bug修改
前端·bug
hj10435 小时前
【fastadmin开发实战】在前端页面中使用bootstraptable以及表格中实现文件上传
前端
乌夷5 小时前
axios结合AbortController取消文件上传
开发语言·前端·javascript