当前位置: 首页 > wzjs >正文

网站建设客服专员企业内训机构

网站建设客服专员,企业内训机构,定制型网站怎么做,互联网保险平台哪家最好包管理工具 npm 包管理工具 介绍 Node Package Manager:也就是Node包管理工具但是目前已经不仅仅是Node包管理器,在前端项目中我们也使用它来管理依赖的包比如 vue、vue-router、vuex、express、koa 下载和安装 npm属于Node的管理工具,安…

包管理工具

npm 包管理工具

介绍

  • Node Package Manager:也就是Node包管理工具
  • 但是目前已经不仅仅是Node包管理器,在前端项目中我们也使用它来管理依赖的包
  • 比如 vue、vue-router、vuex、express、koa

下载和安装

  • npm属于Node的管理工具,安装Node的过程中会自动安装npm工具

package配置文件

  • 必填属性
{// 项目的名称"name":"",// 当前项目的版本号"version":"",// 描述信息"description":"",// 作者相关信息"author":"",// 开源协议"license":""
}
  • private属性:
    • private 是记录当前的项目是否是私有的
    • 当值为true时,npm是不能发布它的,这是防止私有项目或者模块化发布出去的方式
  • main 属性:
    • 设置程序的入口
    • 比如我们使用 axios模块,const axios = require(“axios”)
    • 如果有main属性,实际上是找到对应的main属性查找文件的
  • scripts属性
    • 用于配置一些脚本命令
    • 配置后我们可以通过 npm run 命令的key来执行这个命令
    • 对于常用的start、test、stop、restart可以省略run直接通过npm start 等方式运行
  • dependencies属性
    • dependencies 属性是指定无论开发环境还是生成环境都需要依赖的包
    • 通常是我们项目实际开发用到的一些库模块vue、vuex、vue-router、react、react-dom等等
  • devDependencies
    • 一些包在生产环境是不需要的,比如webpack、babel等
    • npm install webpack --save-dev,将他安装到devDependencies属性中
  • peerDependencies属性
    • 还有一种项目依赖关系是对等依赖,也就是你依赖的一个包,它必须是另外一个宿主包为前提得
    • 比如 element-plus 是依赖vue3 的
  • 依赖管理
    • 安装的依赖版本出现:^2.0.3或者~2.0.3
    • npm的包通常需要遵从semver版本规范
      • semver:https://semver.org/lang/zh-CN/
      • npm semver:https://docs.npmjs.com/misc/semver
    • semver 版本规范 X.Y.Z
      • X主版本号(major):当你做了不兼容的API修改(可能不兼容之前的版本)
      • Y次版本号(minor):当你做了向下兼容的功能性新增(新功能增加,但是兼容之前的版本)
      • Z修订号(patch):当你做了向下兼容的问题修正(没有新功能,修复了之前版本的bug)
  • ^ 和 ~ 的区别
    • x.y.z:表示一个明确的版本号
    • ^x.y.z:表示x保持不变,y和z永远安装最新的版本
    • ~x.y.z:表示x和y保持不变,z永远安装最新的版本
  • engines 属性
    • engines 属性用于指定Node和NPM的版本号
    • 在安装过程中,会先检查对应的引擎版本,如果不符合就会报错
    • 事实上也可以指定所在的操作系统 "os”:[“darwin”,“linux”],只是很少用到
  • browserlist属性
    • 用于配置打包后的JavaScript浏览器的兼容情况
    • 否则我们需要手动添加polyfills来支持某些语法
    • 它是为webpack等打包工具付服务的一个属性
  • 补充
    • 全局安装依赖,会在电脑环境变量中自动添加
npm install webpack -g

会安装到指定目录下
查看安装目录

npm root -g
  • 全局安装是直接将某个包安装到全局
  • 比如全局安装yarn

npm install 原理

在这里插入图片描述

  • npm install 会检测是有package-lock.json文件
    • 没有lock文件
      • 分析依赖关系,可能包会依赖其他的包,并且多个包之间会产生相同的依赖情况;
      • 从registry仓库中下载压缩包(如果我们设置了镜像,那么会从镜像服务器下载压缩包);
      • 获取到压缩包后会对压缩包进行缓存(从npm5开始有的);
      • 将压缩包解压到项目的node_modules文件夹中
    • 有lock文件
      • 检测lock包的版本是否和package.json中一致(会按照semver版本规则检测);
      • 不一致:会重新构建依赖关系,直接走顶层的流程
      • 一致:会优先查找缓存,如果没有找缓存会从registry仓库下载,如果找到会取缓存中的压缩文件,并且压缩文件解压到node_modules文件夹中
  • 常用命令
    • 卸载:npm uninstall
    • 强制重新build:npm rebuild
    • 清楚缓存:npm clear cash
http://www.dtcms.com/wzjs/41825.html

相关文章:

  • 网上做名片的网站百度搜索数据统计
  • 深圳网站建设599元全包长沙网站优化方案
  • 网站开发公司总汇什么都能搜的浏览器
  • 服装公司网站定位武汉新闻最新消息
  • 恒星科技网站建设合肥百度推广排名优化
  • 北京网站代运营公司百度收录是什么意思
  • 网站开发的分录怎么做seo平台怎么样
  • 有些网站为什么会有弹窗淘宝seo是什么意思
  • 网站建设推广型拼多多网店代运营要多少费用
  • 湖南建设厅官方网站网络运营培训哪里有学校
  • 自适应自助建站网站长沙专业seo优化推荐
  • 网站无法发送邮件wordpress佛山seo
  • 家具网站php源码seo云优化是什么意思
  • 网站后台管理系统 静态页面医院营销策略的具体方法
  • 学校建设独立门户网站计划百度关键词排名突然消失了
  • 怎样建个小公司的网站金戈枸橼酸西地那非
  • 中国纪检监察报数字报免费seo培训
  • 企业网站建设价钱友链目录网
  • 深圳商城网站建设如何制作一个个人网站
  • 网站的建设技术有哪些内容推广普通话手抄报一等奖
  • 电商网站 外包东莞网站推广优化网站
  • 赤峰网站建设前端seo是什么
  • 虚拟主机怎么做网站爱战网关键词挖掘查询工具
  • 建网站卖广告爱站网爱情电影网
  • 点击网络怎么做网站seo优化教程自学
  • 动易学校网站电商网站订烟
  • wordpress最新文章调用河北百度seo点击软件
  • 怎样先做网站后买域名百度的seo关键词优化怎么弄
  • 为什么百度不收录wordpress网站推广与优化方案
  • 中国建设银行个人网站注册seo的理解