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来安装你所需的依赖
相关推荐
我要用代码向我喜欢的女孩表白31 分钟前
hadoop常用命令
大数据·hadoop·npm
黑客老陈34 分钟前
基于 Electron 应用的安全测试基础 — 提取和分析 .asar 文件
运维·服务器·前端·javascript·网络·electron·xss
yqcoder41 分钟前
electron 获取本机 ip 地址
前端·javascript·electron
唐某霖2 小时前
el-dialog弹窗的@open方法中,第一次引用ref发现undefined问题,第二次后面又正常了
前端·javascript·vue.js
cdcdhj2 小时前
nodejs后端ws与http结合共享一个服务器,前端websocket发送信息后端ws接收信息,使用Map定型数组设置ID
服务器·前端·http
珹洺2 小时前
音乐播放器实现:前端HTML,CSS,JavaScript综合大项目
开发语言·前端·javascript·css·gitee·bootstrap·html
m0_748251723 小时前
腾讯云AI代码助手评测:如何智能高效完成Go语言Web项目开发
前端·golang·腾讯云ai代码助手
liynet3 小时前
Goland项目内引入字符串标红的解决办法
java·服务器·前端
放下华子我只抽RuiKe53 小时前
Vue进阶之旅:组件通信与高级用法深度剖析(组件通信&进阶用法)
前端·javascript·vue.js·前端框架·node.js·json·html5