如何上传自己的npm包

文章目录

  • 一、创建项目
    • [1.1 第一步注册](#1.1 第一步注册)
    • [1.2 第二步初始化](#1.2 第二步初始化)
    • [1.3 第三步登录](#1.3 第三步登录)
    • [1.4 更改镜像](#1.4 更改镜像)
    • [1.5 上传](#1.5 上传)
    • [1.6 更新上传后的npm包](#1.6 更新上传后的npm包)
  • 二、编写代码
    • [2.1 新建一个文件夹](#2.1 新建一个文件夹)
    • [2.2 初始化](#2.2 初始化)
    • [2.3 package.json配置](#2.3 package.json配置)
    • [2.4 安装依赖模块](#2.4 安装依赖模块)
    • [2.5 创建index.js文件](#2.5 创建index.js文件)
    • [2.6 测试](#2.6 测试)
    • [2.7 上传](#2.7 上传)

npm是什么?

npm是JavaScript软件包管理器,它允许开发人员在项目中方便地安装、发布和共享代码库。可以将其视为一个类似于应用商店的工具,可以帮助开发人员快速地找到、安装和更新他们需要的代码库。

一、创建项目

1.1 第一步注册

去npm的官方网站注册一个账号点击打开链接

1.2 第二步初始化

首先,你需要创建一个新的项目目录。使用以下命令初始化 npm 项目:

bash 复制代码
npm init

初始化一个package.json文件

注意:必须要有这个文件才能上传,npm可以上传任何一个包含package.json的包,package.json的main(入口)设置为index.js(名字自取)然后在本目录下建一个index.js文件,name表示你这个包的名字只能小写,version代表版本,每次更新都要修改这里的版本再npm publish

package.json可以在这里了解一下点击打开链接

1.3 第三步登录

在本地使用命令行连接npm 使用下面的命令 然后按照提示走,密码默认是不会显示出来的

bash 复制代码
npm login 或者 npm adduser

1.4 更改镜像

因为大部分的人npm使用的是淘宝镜像,上传会失败,所以需要替换为原来的镜像

https://registry.npmjs.org/

bash 复制代码
npm config set registry https://registry.npmjs.org/

再查看是否设置成功

bash 复制代码
npm config get registry

更改了镜像需要按照前面说过的步骤,重新在本地登陆你的npm账户

1.5 上传

上传

bash 复制代码
npm publish

撤销上传(如果想删除已经上传了的包,可以在package.json所在目录使用以下命令)

bash 复制代码
npm unpublish --force

1.6 更新上传后的npm包

  1. 手动去package.json里面修改版本号,修改后的版本号必须比之前的大,然后使用npm publish上传
  2. 使用npm 命令行工具更新版本号,再使用npm publish 上传

注意事项:

你必须使用exports暴露你的方法,如下定义了一个npmTest的方法然后暴露出来,才能在安装这个包之后使用require引入

js 复制代码
exports.npmTest = (name) => {
    console.log(name)
}

另外平时我们在github上看到的readme.md的样式是用过MarkDow语法来实现的,这个语法实现起来很简单,MarkFown的yu语法在这里了解点击打开链接

二、编写代码

2.1 新建一个文件夹

首先,在本地新建一个文件夹,命名为"desensitization",并进入该文件夹。

bash 复制代码
mkdir desensitization
cd desensitization

2.2 初始化

使用npm初始化这个文件夹,并生成package.json文件。

bash 复制代码
npm init

2.3 package.json配置

在package.json文件中添加"name"、"version"、"description"、"main"等信息。

json 复制代码
{
  "name": "desensitization",
  "version": "1.0.0",
  "description": "A JavaScript module for masking names",
  "main": "index.js",
  "dependencies": {}
}

2.4 安装依赖模块

安装依赖模块"lodash"和"string-mask"。

bash 复制代码
npm install lodash string-mask --save

2.5 创建index.js文件

javascript 复制代码
const _ = require('lodash');
const StringMask = require('string-mask');

function maskName(name) {
  const firstName = _.capitalize(name.split(' ')[0]);
  const otherName = name.split(' ').slice(1).map(n => n[0].toUpperCase() + '.');
  const maskedName = [firstName, ...otherName].join(' ');
  
  return new StringMask('XXX XX').apply(maskedName);
}

module.exports = maskName;

2.6 测试

在根目录下创建一个名为"test.js"的文件,并添加以下代码

java 复制代码
const maskName = require('./index');

const name = 'John Smith';
const maskedName = maskName(name);

console.log(maskedName); // "XXX Xx"

2.7 上传

执行命令"npm publish",将模块上传至npm上。

bash 复制代码
npm publish

上传成功后,其他用户就可以使用npm install desensitization命令安装你编写的脱敏模块并使用了。

相关推荐
LFly_ice9 分钟前
学习React-10-useTransition
前端·学习·react.js
咔咔一顿操作10 分钟前
【CSS 3D 交互】实现精美翻牌效果:从原理到实战
前端·css·3d·交互·css3
知识分享小能手14 分钟前
React学习教程,从入门到精通,React 构造函数(Constructor)完整语法知识点与案例详解(16)
前端·javascript·学习·react.js·架构·前端框架·vue
召摇19 分钟前
Nue.js深度解析:极简主义前端框架的革新实践
前端·node.js
小徐_233322 分钟前
uni-app 也能使用 App.vue?wot-starter 是这样实现的!
前端·uni-app
入秋24 分钟前
Three.js后期处理实战:镜头颜色、色差、点阵与颜色管道的深度解析
前端·three.js
深圳外环高速24 分钟前
企业微信和页面离开事件
前端
召摇26 分钟前
NodeBB 深度解析:现代论坛系统的架构设计与实践指南
前端·javascript
哆啦A梦158840 分钟前
uniapp分包实现
前端·vue.js·uni-app·vue3
wordbaby44 分钟前
Hooks的革命:让React的非UI逻辑也能像UI组件一样自由复用和组合
前端·react.js