zoukankan      html  css  js  c++  java
  • 如何开发一个npm包并发布到npm中央仓库

    转自: https://liaolongdong.com/2019/01/24/publish-public-npm.html

    如何开发一个npm包并发布到npm中央仓库
    需求背景:平时在项目工作中可能会用到很多通用性的代码,比如,框架类、工具类以及公用的业务逻辑代码等等,通过打包发布到npm中央仓库或者私有仓库,来进行维护和托管代码,方便公用代码的使用,如果涉及到不方便公开的代码组件可以发布到私有仓库。

    npm包命名规则及文件夹结构
    用模块的名称命名根目录,npm包名不能重复

    每个npm包根目录下都包含一个index.js文件和package.json文件

    src目录,用于放置未压缩的源码

    dist目录,用于放置压缩后的代码

    使用package.json文件的规格来描述本模块

    发布npm到npm中央仓库(公共仓库)
    1、注册npm账号
    我们在发布npm包之前,要去npm官网注册一个账号,注册完账号以后,点击邮件链接完成验证

    2、编写模块
    首相,创建publishNpm文件夹,在该文件夹下添加helloworld.js文件和index.js文件,代码如下:

    // 创建模块目录
    mkdir publishNpm
    
    // 进入目录
    cd publishNpm
    
    // 创建helloworld.js文件和index.js文件
    touch helloworld.js index.js
    // helloworld.js文件
    
    function helloworld (name) {
    console.log('hello world,', name);
    }
    exports.helloworld = helloworld;
    // index.js文件
    
    var helloworld = require('./helloworld');
    console.log('helloworld', helloworld);
    helloworld.helloworld('better');
    

      

    接下来,在publishNpm目录下,执行npm init命令,初始化package.json文件

    npm init
    // package.json 文件
    
    {
    "name": "lld-npm-demo",
    "version": "1.0.1",
    "description": "publish npm demo",
    "main": "index.js",
    "scripts": {
    "test": "echo "Error: no test specified" && exit 1"
    },
    "author": "better",
    "license": "ISC"
    }
    

      

    注意:1、npm包名称name的值不能和已经存在的npm包名相同;2、每次版本更新都必须修改版本号version的值

    3、发布npm到npm公共仓库
    添加账户

    npm adduser


    输入用户名、密码和邮箱

    查看当前登录的用户

    npm who am i


    发布npm包

    npm publish


    发布成功以后,就可以在npm个人中心看到刚刚发布的npm包了

    更新npm包
    和发布npm一样都是使用npm publish命令,更新发布之前必须修改版本号

    使用npm
    和我们平时使用npm一样

    npm install lld-npm-demo


    发布npm常见错误
    1、npm仓库设置了淘宝镜像

    npm ERR! code E403
    npm ERR! 403 Forbidden - PUT https://registry.npm.taobao.org/lld-npm-demo - no_perms
    
    npm ERR! A complete log of this run can be found in:
    npm ERR! /Users/better/.npm/_logs/2019-01-24T02_08_54_914Z-debug.log
    解决方案:
    
    // 检查仓库是否被设成了淘宝镜像库(https://registry.npm.taobao.org/)
    npm config get registry
    
    // 如果设置了淘宝镜像,执行以下命令
    npm config set registry=http://registry.npmjs.org
    
    // 解决问题后重新发布
    npm publish
    
    // 发布成功以后,在设会淘宝镜像
    npm config set registry=https://registry.npm.taobao.org/
    

      

    2、账号未登录

    npm ERR! code E401
    npm ERR! 401 Unauthorized - PUT http://registry.npmjs.org/lld-npm-demo - You must be logged in to publish packages.
    
    npm ERR! A complete log of this run can be found in:
    npm ERR! /Users/better/.npm/_logs/2019-01-24T02_13_00_370Z-debug.log
    解决方案:
    
    // 登录用户 npm login
    npm adduser
    
    // 登录用户以后重新发布
    npm publish
    

      

    3、重新发布未修改版本号

    npm ERR! code E403
    npm ERR! 403 Forbidden - PUT http://registry.npmjs.org/lld-npm-demo - You cannot publish over the previously published versions: 1.0.0.
    
    npm ERR! A complete log of this run can be found in:
    npm ERR! /Users/better/.npm/_logs/2019-01-24T02_55_19_409Z-debug.log
    解决方案:在package.json文件修改版本号
    

      

  • 相关阅读:
    1.2 偏差与方差
    深度学习中Xavier初始化
    1.1 训练/开发/测试集
    Python笔记(5)类__方法与继承
    Python笔记(4)类__属性与描述符
    Python笔记(3)迭代器与生成器
    Python笔记(2)函数
    线性回归 Linear Regression
    Python笔记(1)变量与表达式
    跳转到某个Activity
  • 原文地址:https://www.cnblogs.com/shuiche/p/11435361.html
Copyright © 2011-2022 走看看