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 可能不是最新版本,最后用下面的命令,更新到最新版本。// Windownpm install npm -g// Linux$ sudo npm install npm@latest -gnpm initnpm 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)) })});