npm 模块的组成和发布

栏目: Node.js · 发布时间: 5年前

内容简介:在手头的项目中,由于业务所属范围的区分,团队之间负责的不同的业务,但是需要把这些业务整合到同一个侧边栏中,且需要使用相同的权限控制系统。所以决定将侧边栏,以顶部状态栏抽离成一个 framework,发布到 npm ,其余子项目中共同发布。但是我真的对 npm、node_module 的原理不是很熟悉。那么下面我来整理一番。

在手头的项目中,由于业务所属范围的区分,团队之间负责的不同的业务,但是需要把这些业务整合到同一个侧边栏中,且需要使用相同的权限控制系统。

所以决定将侧边栏,以顶部状态栏抽离成一个 framework,发布到 npm ,其余子项目中共同发布。

但是我真的对 npm、node_module 的原理不是很熟悉。那么下面我来整理一番。

node_modules

使用 npm install XXX ,当前项目会自动生成 node_modules 文件夹。我们从它说起。

require

在 node 环境下输出 module ,得到如下结果。

╭─~/MyWorkspace/npm-module
╰─➤  node
> module
Module {
  id: '<repl>',
  exports: {},
  parent: undefined,
  filename: null,
  loaded: false,
  children: [],
  paths:
   [ '/Users/leiliao/MyWorkspace/npm-module/repl/node_modules',
     '/Users/leiliao/MyWorkspace/npm-module/node_modules',
     '/Users/leiliao/MyWorkspace/node_modules',
     '/Users/leiliao/node_modules',
     '/Users/node_modules',
     '/node_modules',
     '/Users/leiliao/.node_modules',
     '/Users/leiliao/.node_libraries',
     '/Users/leiliao/.nvm/versions/node/v10.15.3/lib/node' ] }
>
复制代码

id 是表示 module 的唯一标示,我们把重点放到 paths 中,当我们使用 import 或者 require 命令时,会从 paths 中的如下路径依次寻找。

在当前项目根目录下 也就是 /MyWorkspace/npm-module 新建 node_modules 文件,然后在 node_modules 中新建 framework.js 文件 console.log('i am framework');

- node_modules
    -  framework.js 
- index.js
复制代码

在当前项目根目录下新建 index.js , require('framework');

使用 node index ,输出 i am framework , 使用 require 在 /Users/leiliao/MyWorkspace/npm-module/node_modules 找到了 framework.js

注意,如果在项目根目录和 node_modules 中同时存在 framework.js 会优先寻找 node_modules 的文件。

- node_modules
    - frameworkjs 
- index.js
- frameworkjs  
复制代码

我们在 node_modules 创建一个 framework 文件夹,具体文件结构如下

- node_modules
    - framework
        - index.js
        - start.js
        - package.json
- index.js
- framework.js 
复制代码

使用 require('framework'); 时, 如果 framework 文件夹中没有 package.json 文件,默认寻找当前文件夹 index.js ,如果有 package.json 文件,则寻找 "main" 字段中的路径。 比如 "main": "start.js",

package.json

来看一段 package 的文件。

{
  "name": "npm-framework-test",
  "version": "a.b.c",
  "license": "MIT",
  "description": "",
  "author": "Leo",
  "files": [
    "src",
    "public",
    "dist",
    "webpack"
  ],
  "scripts": {
    "build": "node build/build.js",
    "start": "node build/dev-server.js"
    "prepublish": "npm run build"
  },
  "main": "dist/index.js",
  "types": "dist/index.d.ts",
  "dependencies": {
    "js-cookie": "^2.2.0",
    "uuid": "^3.2.1"
  },
  "devDependencies": {
    "autoprefixer": "^8.6.2",
    "axios": "0.18.0",
    "vue": "^2.5.16",
  },
  "peerDependencies": {
    "axios": "^0.18.0",
    "vue": "^2.5.16",
  },
  "engines": {
    "node": ">= 6.0.0",
    "npm": ">= 4.0.0"
  },
  "browserslist": [
    "> 1%",
    "last 2 versions",
    "not ie <= 8"
  ]
}

复制代码

对一下规则做出解释

version

即 "版本号",当使用 npm i 时每一个模块都默认带有版本号,且版本号不能重复,以 "version": "a.b.c", 作为例子。

  • a - major version 大版本的升级意味着与低版本的不兼容和重大升级,比如 vue2.x -> vue3.x
  • b - minor version 小版本的升级在当前大版本下的 api 和 使用都是兼容的。
  • c - patch 用于修复 bug 等。

"1.2.3-beta.2" - 带预发布关键词的,如 alpha, beta, rc, pr 等。

使用 npm i 具体安装某个模块。使用 npm outdated npm outdated。

╭─~/MyWorkspace/npm-module
╰─➤  npm view vue versions

[ 
  ...
  '2.0.0',
  '2.0.1',
  '2.0.2',
  '2.0.3',
  '2.0.4',
  '2.0.5',
  '2.0.6',
  '2.0.7',
  '2.0.8',
  '2.1.0',
  '2.1.1',
  '2.1.2',
  '2.1.3',
  '2.1.4',
  '2.1.5',
  '2.1.6',
  '2.1.7',
  '2.1.8',
  '2.1.9',
  '2.1.10',
  ...
  '2.2.0',
  '2.2.3',
  '2.2.4',
  '2.2.5',
  '2.2.6',
  '2.3.0-beta.1',
  '2.3.0',
  '2.3.1',
  '2.3.2',
  ...
  '2.5.17-beta.0',
  '2.5.17',
  '2.5.18-beta.0',
  '2.5.18',
  '2.5.19',
  '2.5.20',
  '2.5.21',
  '2.5.22',
  ...
  '2.6.8',
  '2.6.9',
  '2.6.10' ]
复制代码

首先需要在新建文件夹中 npm init

  • npm i vue
╭─~/MyWorkspace/npm-module
╰─➤  npm i vue

+ vue@2.6.10
added 1 package from 1 contributor in 1.658s

复制代码

我们可以看到默认安装了当前的最新版本。

  • npm i vue@x.x.x

请使用npm uninstall 卸载重复的模块

指定版本进行安装

╭─~/MyWorkspace/npm-module
╰─➤  npm i vue@2.0.0

+ vue@2.0.0
added 1 package from 1 contributor in 1.986s
复制代码

版本范围匹配

─~/MyWorkspace/npm-module
╰─➤  npm i vue@^2.1.1
npm WARN npm-module@1.0.0 No description
npm WARN npm-module@1.0.0 No repository field.

+ vue@2.6.10
added 1 package from 1 contributor in 1.38s
复制代码

^2.1.1 安装 2.x.x 版本下的最高版本。

╭─~/MyWorkspace/npm-module
╰─➤  npm i vue@~2.1.1
npm WARN npm-module@1.0.0 No description
npm WARN npm-module@1.0.0 No repository field.

+ vue@2.1.10
added 1 package from 1 contributor in 1.716s
复制代码

~2.1.1 安装 2.1.x 下的最高版本。

以下需要在 package.json 指定后,再使用 npm i 进行安装。 >=2.1.1 安装大于或等于 2.1.1 的最高版本, <=2.1.1 同理。

license

模块的遵守的协议吃,常见的是MIT 。我们使用阮一峰 老师的图。

npm 模块的组成和发布

peerDependencies

主要是用在 framework 的开发时,现有项目依赖于 framework 但是,某些特殊的依赖又不想被 framework 给限制在本版本当中(想使用更高的版本)。

比如 framework 中依赖 "axios": "0.18.1", 在 peerDependencies 中声明 "axios": "^0.18.1" 后,在实际项目中安装大于 0.18.1 的版本,framework会优先使用项目中的现有高版本。

npm or yarn

yarn 的出现只要是想解决早期 npm 下载速度和版本锁定的问题。但是现在 npm > 5 的版本中已经没有这些问题了。

需要注意的是:项目请使用单一管理包 工具 进行管理,不是使用 npm 和 yarn 混用。

发布

注册

npm 现有社区最大的平台就是npmjs。我们一般会从这上面取轮子。

但是各个公司中会存在自己的 npm 库。在注册之前需要指定全局的 npm 仓库地址。

# 将registry 指定为需要发布的库
npm config set registry registry https://registry.npmjs.org/

# 可查看当前库的指向
npm config list
复制代码

可以在npm 官网 直接注册,也可以使用以下命令:

npm adduser
复制代码

准备一个 npm 包

在上文中已经讲到 node_modules 如何能够被 require,这里使用 package.json 的方式。

如上文中的 package.json , 其中 scripts 字段中的 prepublish 命令,可以在发布之前会prepublish

上传远程仓库

╭─~
╰─➤  npm login
Username: leolei
Password:
Email: (this IS public) 810364013@qq.com
Logged in as leolei on https://registry.npmjs.org/.

╭─~/MyWorkspace/npm-module
╰─➤  npm publish                                                            
npm notice
npm notice :package:  npm-framework-test@1.0.0
npm notice === Tarball Contents ===
npm notice 242B package.json
npm notice 47B  index.js
npm notice === Tarball Details ===
npm notice name:          npm-framework-test
npm notice version:       1.0.0
npm notice package size:  322 B
npm notice unpacked size: 289 B
npm notice shasum:        ae09a4635fbcf27b34ad6c643038ceb7d20de8dc
npm notice integrity:     sha512-50nWTjDIq03U8[...]t8ZW8iGTngnxQ==
npm notice total files:   2
npm notice
+ npm-framework-test@1.0.0

复制代码

发布失败可能是包名重复,版本号重复,登录失败等原因。

登录 npm 就可以看到发布信息。

npm 模块的组成和发布

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

Web Design for ROI

Web Design for ROI

Lance Loveday、Sandra Niehaus / New Riders Press / 2007-10-27 / USD 39.99

Your web site is a business--design it like one. Billions of dollars in spending decisions are influenced by web sites. So why aren't businesses laser-focused on designing their sites to maximize thei......一起来看看 《Web Design for ROI》 这本书的介绍吧!

JS 压缩/解压工具
JS 压缩/解压工具

在线压缩/解压 JS 代码

CSS 压缩/解压工具
CSS 压缩/解压工具

在线压缩/解压 CSS 代码

SHA 加密
SHA 加密

SHA 加密工具