nodejs中标准包的制作,上传,安装及卸载方法

一:如何制作一个标准包?

为了规范化,基本遵循CommonJS规范,首先约定:

包的使用:

  • 所有模块放在一个文件夹(包名)
  • 包放在当前项目中的node_modules文件夹下
  • 包中定义一个index.js(文件名不可以更改)导出所有模块(出口)
  • 引用包(约定大于配置)

Node.js在调用包时,首先会检查包中的package.json文件的main字段,将其作为包的接口模块,如果package.json文件的main字段不存在,那么Node.js会尝试寻找index.js或index.node作为包的接口。

以下是一个非常简单的标准包的参照:

标准包的结构:

名称 |功能 |---|---| package.js |包描述文件 bin |存放可执行文件 lib |存放JavaScript代码 doc |存放文档 test |存放单元测试用例代码 README.md |说明文档,描述包的作用和用法

如何打包生成package.json文件?

我们以下面这个还未打包的package为例:

步骤: 1.自己创建README.md说明文件,注意修改后缀名

2.在根目录package下执行命令窗口

npm init -y  //自动创建package.json

当然如果想要自己手动创建就不要加 -y输入 npm init即可

name:(package)    //包名:(括号内为默认值下同) 回车

version:(1.0.0)       //版本

git repository:        //模块的git仓库,选填。npm的用户一般都使用github做为自己的git       仓库

author:              //模块的作者名

License:(ISC)             //许可证 默认括号中的

IS this ok?(yes)         //输入yes即可生成

二:如何发布一个包?

1)发布一个包的步骤:

当我们创建完了一个包我们便会将其上传到npm的官网上去,以供其他人来使用

第一步:在npm官网 https://www.npmjs.com/上注册一个账号

第二步:登录

在包的根目录下面执行打开dos窗口(我这里的需要上传的包为math文件夹)(找到这个文件夹所在位置,按住shift右击, 点击”在此处打开命令窗口”)

npm adduser        //回车后,弹出Username:

Username:          //输入你在官网注册时的用户名,回车

Password:          //输入官网注册的密码,密码看不见,请确保你输的密码正确, 回车

Email:(this is Public)    //输入官网注册时绑定的邮箱,回车

第三步:上传

npm publish        //此处上传命令,回车

上传成功如下图:

2)发布一个包的时候容易遇到的问题:

  • 1.切换的源不对,很可能你现在的源是taobao等其他来源
  • 报错信息会中含有:
  • only admin can publish this module

解决办法:修改源 npm config set registry http://registry.npmjs.org

查看是否切换源成功: npm config list

当跳出的信息中含有registry = "http://registry.npmjs.org/"表示切换源成功

2.你的包名与npm官网上别人上传的包重名了,会报以下错误

解决办法有两种:

1.修改你包中的package.json文件中的name(即包的名字)

2.修改你包的版本名

三:安装包

在新建的文件的根目录下执行

npm install 需要的包名  //安装包

npm uninstall 需要删除的包名  //卸载包

在新建的文件下的根目录执行

npm install 包名 --save  // 建立包依赖

时间: 2024-10-25 15:11:28

nodejs中标准包的制作,上传,安装及卸载方法的相关文章

nodeJS中的包

前面的话 Node组织了自身的核心模块,也使得第三方文件模块可以有序地编写和使用.但是在第三方模块中,模块与模块之间仍然是散列在各地的,相互之间不能直接引用.而在模块之外,包和NPM则是将模块联系起来的一种机制.在介绍NPM之前,不得不提起CommonJS的包规范.JavaScript不似Java或者其他语言那样,具有模块和包结构.Node对模块规范的实现,一定程度上解决了变量依赖.依赖关系等代码组织性问题.包的出现,则是在模块的基础上进一步组织JavaScript代码.CommonJS的包规范

nodeJS中的包 npm install http://www.cnblogs.com/xiaohuochai/archive/2017/05/20/6882027.html

前面的话 Node组织了自身的核心模块,也使得第三方文件模块可以有序地编写和使用.但是在第三方模块中,模块与模块之间仍然是散列在各地的,相互之间不能直接引用.而在模块之外,包和NPM则是将模块联系起来的一种机制.在介绍NPM之前,不得不提起CommonJS的包规范.JavaScript不似Java或者其他语言那样,具有模块和包结构.Node对模块规范的实现,一定程度上解决了变量依赖.依赖关系等代码组织性问题.包的出现,则是在模块的基础上进一步组织JavaScript代码.CommonJS的包规范

ueditor1.3.6jsp版在struts2应用中上传图片报"未找到上传文件"解决方案

摘要: ueditor1.3.6jsp版在struts2应用中上传图片报"未找到上传文件"解决方案 在struts2应用中使用ueditor富文本编辑器上传图片或者附件时,即使配置好了上传路径信息,也会出现"未找到上传文件"的错误提示,出先该问题的原因是:在配置struts过滤器,过滤路径设置/*方式时,由于struts2框架默认使用apache的Commons FileUpload组件和内建的FileUploadInterceptor拦截器实现上传,会将reque

利用socket模拟http的混合表单上传(在一个请求中提交表单并上传多个文件)

在很多企业级应用中,我们都没法直接通过开发语言sdk包封装的http工具来模拟http复合表单(multipart/form-data),特别是在跨语言跨平台的编程过程中,其实实现方案并不复杂,只要你了解了http协议中复合表单的报文结构就很简单了: httpheader ------时间戳------ 表单参数1 ------时间戳------ 表单参数2 ------时间戳------ 文件1的描述+二进制信息 ------时间戳------ 文件2的描述+二进制信息 下面我们进一步以一段c

发布新的模型类包(用于上传到 NuGet 服务器上)

生成包文件: 1.修改了模型类之后,在项目上点击右键,在列表菜单中选择 “编辑 …….csproj”,然后将里面的三个版本号都换成新的版本号. 2.右键项目,点击“打包” 3.复制输出信息中生成的包的文件夹(注意,复制文件夹路径)路径,如 “1>Successfully created package 'D:\ProjectCode\……\bin\Debug\…….1.8.5.nupkg'.” 中的 “D:\ProjectCode\……\bin\Debug”(用Debug发布也不影响) 4.需要

不借助第三方jar包实现文件上传

如果实现文件上传难道非要借助第三方jar包(最常用的莫过于apache的commons-fileupload工具包)来实现吗?答案是否定的,下面通过例子演示在不借助第三方jar包的前提下如何实现文件的上传: 一.第一种实现方式 正在总结稍等!!! 二.第二种实现方式 正在总结稍等!!! 不借助第三方jar包实现文件上传,布布扣,bubuko.com

不使用ASP.NET中的服务器控件将如何上传文件?

遇到文件的上传时,可能会有大部分的开发者喜欢使用服务器控件,虽然很方便,但是却不能很好的控制,不具灵活性. 现给出例子,使用html标签语言灵活的控制文件的上传. 1.html部分 <input type="file" id="uploadFile" name="uploadFile" style="display: none;"/> <a href="#" id="upload

WPF中利用WebClient向服务器上传文件

转载:原文地址http://blog.csdn.net/wj1589300/article/details/9255631 WPF中利用WebClient向服务器上传文件 忽然接到一个任务,在WPF中上传文件至服务器~在网上搜了很多种方法,最终决定利用WebCient实现文件的上传工作,看似很简单的任务,却遇到了很多问题.先说一下我的探索步骤吧~ 一.选用WebClient.UploadFile方法 (String,String, String) [csharp] view plaincopyp

magento -- 如何在magento中进行产品的批量上传

花费了好多时间,阅读了magento官方论坛上几乎所有的批量上传产品的相关帖子,分析了大量相关magento代码,终于可以完全实现指产品批量上传的功能,免除网速慢,在页面之间跳来跳去,以及重复输入数据的烦恼,你只需要在excel中编辑数据就可以轻松实现产品批量上传到magento站点. 碰到的常见问题(统统搞定,哈哈): 多图上传 上传后magento前台无法查看 上传后前台看不了图片 上传后前台只能看到部分图片 上传后前台的图片有重复 不能上传custom option(可以支持基于optio