npm使用教程

24次阅读

共计 2132 个字符,预计需要花费 6 分钟才能阅读完成。

NPM
是什么
npm 之于 Node.js,就像 pip 之于 Python,gem 之于 Ruby,pear 之于 PHP。npm 是 Node.js 官方提供的包管理工具,他已经成了 Node.js 包的标准发布平台,用于 Node.js 包的发布、传播、依赖控制。npm 提供了命令行工具,使你可以方便地下载、安装、升级、删除包,也可以让你作为开发者发布并维护包。

为什么
npm 是随同 Node.js 一起安装的包管理工具,能解决 Node.js 代码部署上的很多问题,常见的场景有以下几种:
允许用户从 npm 服务器下载别人编写的第三方包到本地使用。允许用户从 npm 服务器下载并安装别人编写的命令行程序到本地使用。允许用户将自己编写的包或命令行程序上传到 npm 服务器供别人使用。
npm 的背后,是基于 couchdb 的一个数据库,详细记录了每个包的信息,包括作者、版本、依赖、授权信息等。它的一个很重要的作用就是:将开发者从繁琐的包管理工作(版本、依赖等)中解放出来,更加专注于功能的开发。
怎么用
npm 不需要单独安装。在安装 Node 的时候,会连带一起安装 npm。但是,Node 附带的 npm 可能不是最新版本,最后用下面的命令,更新到最新版本。
// Window
npm install npm -g
// Linux
$ sudo npm install npm@latest -g
npm init
npm init 用来初始化生成一个新的 package.json 文件。它会向用户提问一系列配置相关的问题,如果你觉得不用修改默认配置,一路回车就可以了。

smartAdmin
{
“name”: “smartadmin-angularjs-app”,
“version”: “1.8.1”,
“description”: “Demo Application for AngularJS version of SmartAdmin application template”,
“main”: “index.html”,
“private”: true,
“scripts”: {
“dev”: “gulp dev”,
“prod”: “gulp prod”
},
“author”: “Sunny”,
“license”: “MyOrange Inc.”,
“devDependencies”: {
“gulp”: “^3.9.0”,
“gulp-concat”: “^2.6.0”,
“gulp-angular-templatecache”: “^1.7.0”,
“gulp-connect”: “^2.2.0”,
“gulp-ng-annotate”: “^1.0.0”,
“gulp-uglify”: “^1.2.0”,
“event-stream”: “~3.3.1”,
“lodash”: “^4.0.0”
}
}
GULP
通过代码优于配置的策略,Gulp 让简单的任务简单,复杂的任务可管理。利用 Node.js 流的威力,你可以快速构建项目并减少频繁的 IO 操作。Gulp 严格的插件指南确保插件如你期望的那样简洁高质得工作。

var gulp = require(‘gulp’);
gulp.task(‘default’, function() {
// 将你的默认的任务代码放在这
});
代码片段
gulp.task(‘dev’, [‘vendor’, ‘js’, ‘watch’, ‘connect’]);
gulp.task(‘default’, [‘dev’]);

gulp.task(‘js’, function () {
return es.merge(gulp.src(source.js.src), getTemplateStream())
.pipe(concat(‘app.js’))
.pipe(gulp.dest(destinations.js));
});

gulp.task(‘watch’, function () {
gulp.watch(source.js.src, [‘js’]);
gulp.watch(source.js.tpl, [‘js’]);
});

gulp.task(‘connect’, function () {
connect.server({
port: 16701
});
});

gulp.task(‘vendor’, function () {
_.forIn(scripts.chunks, function (chunkScripts, chunkName) {
var paths = [];
chunkScripts.forEach(function (script) {
var scriptFileName = scripts.paths[script];

if (!fs.existsSync(__dirname + ‘/’ + scriptFileName)) {

throw console.error(‘Required path doesn\’t exist: ‘ + __dirname + ‘/’ + scriptFileName, script)
}
paths.push(scriptFileName);
});
gulp.src(paths)
.pipe(concat(chunkName + ‘.js’))
//.on(‘error’, swallowError)
.pipe(gulp.dest(destinations.js))
})

});

正文完
 0