node,npm在前端开发流程中提供了非常完善的自动化工具链,但是同样由于其复杂性导致有很多奇奇怪怪的问题。本文将记录使用过程中出现的一些问题及其解决方法备案。
1.使用一个proxy来代理访问,但是这个方法速度可能比较慢;
2.可以通过修改npm的配置文件让npm到另外的pacakge mirror站点去找package,通过如下命令
$npm config set registry https://registry.npm.taobao.org
$ npm config set registry http://r.cnpmjs.org
或者:npm config set registry http://registry.npmjs.eu
npm install
随后再执行
或者直接在命令行中指定某些参数,比如phantomjs是一个无图形界面的浏览器,在自动化测试中应用广泛,可能的安装方式:
npm install phantomjs --phantomjs_cdnurl=http://cnpmjs.org/downloads
如果上述方法都不奏效,那么可能需要 配置自己网卡的dns为国外的dns
npm config set proxy http://proxy.company.com:8080 npm config set https-proxy http://proxy.company.com:8080
// 或者簡單粗暴地简化为在git-bash界面中设置(包括支持s本地代理):
export {http,https,ftp}_proxy=‘http://192.168.0.11:1080'
$ npm install -g gulp npm ERR! tar.unpack untar error /home/cabox/.npm/gulp/3.9.0/package.tgz npm ERR! Linux 2.6.32-042stab104.1 npm ERR! argv "/usr/local/bin/node" "/usr/local/bin/npm" "install" "-g" "gulp" npm ERR! node v0.12.3 npm ERR! npm v2.9.1 npm ERR! path /usr/local/lib/node_modules/gulp npm ERR! code EACCES npm ERR! errno -13 npm ERR! Error: EACCES, mkdir '/usr/local/lib/node_modules/gulp' npm ERR! at Error (native) npm ERR! { [Error: EACCES, mkdir '/usr/local/lib/node_modules/gulp'] npm ERR! errno: -13, npm ERR! code: 'EACCES', npm ERR! path: '/usr/local/lib/node_modules/gulp', npm ERR! fstream_type: 'Directory', npm ERR! fstream_path: '/usr/local/lib/node_modules/gulp', npm ERR! fstream_class: 'DirWriter', npm ERR! fstream_stack: npm ERR! [ '/usr/local/lib/node_modules/npm/node_modules/fstream/lib/dir-writer.js:36:23', npm ERR! '/usr/local/lib/node_modules/npm/node_modules/mkdirp/index.js:46:53', npm ERR! 'FSReqWrap.oncomplete (fs.js:95:15)' ] } npm ERR! npm ERR! Please try running this command again as root/Administrator. npm ERR! Please include the following file with any support request: npm ERR! /home/cabox/npm-debug.log
可能的解决方案是修改npm将安装的目标目录的ownershipi:
$ npm config get prefix /usr/local $ whoami cabox
上面的命令可以查到你是以cabox用户来运行命令的,npm将全局package安装package到/usr/local下面的lib/node_modules目录下面,比如gulp,bower,grunt等需要全局安装的node module都将存放到这里,而如果你对该目录没有写的权限,则会出现问题,因此你可以做的是chown -R /usr/local your_username
但是这个方案也是有缺点的,特别是当一个系统中有多个用户使用时,你把这些公共目录都搞成你自己的ownership,可能会存在问题。
另外一种可能的解决方案修改上述prefix,指定npm的全局package安装目录为自己的Home目录下面的子目录,同时需要将上述子目录放到path中去,这样就能够将npm的全局package安装到这个我们有权限控制的目录中了
$ npm config set prefix /home/cabox/npm-global/ $ npm config get prefix /home/cabox/npm-global $ gulp -bash: gulp: command not found $ npm install -g gulp /home/cabox/npm-global/bin/gulp -> /home/cabox/npm-global/lib/node_modules/gulp/bin/gulp.js gulp@3.9.0 /home/cabox/npm-global/lib/node_modules/gulp ├── pretty-hrtime@1.0.0 ├── interpret@0.6.2 ├── deprecated@0.0.1 ├── archy@1.0.0 ├── minimist@1.1.1 ├── tildify@1.0.0 (user-home@1.1.1) ├── v8flags@2.0.5 (user-home@1.1.1) ├── chalk@1.0.0 (escape-string-regexp@1.0.3, ansi-styles@2.0.1, supports-color@1.3.1, strip-ansi@2.0.1, has-ansi@1.0.3) ├── semver@4.3.6 ├── orchestrator@0.3.7 (stream-consume@0.1.0, sequencify@0.0.7, end-of-stream@0.1.5) ├── liftoff@2.1.0 (extend@2.0.1, rechoir@0.6.1, flagged-respawn@0.3.1, resolve@1.1.6, findup-sync@0.2.1) ├── gulp-util@3.0.5 (array-differ@1.0.0, array-uniq@1.0.2, lodash._reescape@3.0.0, lodash._reevaluate@3.0.0, beeper@1.1.0, lodash._reinterpolate@3.0.0, object-assign@2.1.1 , replace-ext@0.0.1, vinyl@0.4.6, lodash.template@3.6.1, through2@0.6.5, multipipe@0.1.2, dateformat@1.0.11) └── vinyl-fs@0.3.13 (graceful-fs@3.0.8, strip-bom@1.0.0, defaults@1.0.2, vinyl@0.4.6, mkdirp@0.5.1, through2@0.6.5, glob-stream@3.1.18, glob-watcher@0.0.6)
上面使用cabox用户安装gulp到/home/cabox/npm-global目录中去了。
详细参照下面的两篇文章:
http://www.johnpapa.net/how-to-use-npm-global-without-sudo-on-osx/
https://github.com/sindresorhus/guides/blob/master/npm-global-without-sudo.md
但是现在还有一个问题,那就是系统path中并没有包含该目录,因此直接运行gulp还是无法找到的
在.bash_profile中添加以下:
npm install -g npm@latest或npm install npm -g npm cache clear && rm -rf node_modules && npm install
[cabox@box-codeanywhere npmtest]$ npm install --save lodash npm WARN package.json kidsit@1.0.0 No repository field. npm WARN package.json kidsit@1.0.0 No README data lodash@3.9.3 node_modules/lodash [cabox@box-codeanywhere npmtest]$ ls node_modules package.json [cabox@box-codeanywhere npmtest]$ vi package.json [cabox@box-codeanywhere npmtest]$ ls node_modules package.json [cabox@box-codeanywhere npmtest]$ npm ls kidsit@1.0.0 /home/cabox/workspace/npmtest └── lodash@3.9.3 [cabox@box-codeanywhere npmtest]$ npm uninstall lodash --save unbuild lodash@3.9.3
在这里如果node系统的模块安装有问题,这里会主动列出来:
├── [email protected]
├─┬ [email protected]
│ ├─┬ [email protected]
│ │ └─┬ [email protected]
│ │ ├── [email protected]
│ │ ├── [email protected]
│ │ └── [email protected]
│ ├─┬ [email protected]
│ │ └─┬ [email protected]
│ │ ├── [email protected]
│ │ ├── [email protected]
│ │ └── [email protected]
│ └── [email protected]
├── [email protected]
└── [email protected]
npm ERR! missing: [email protected], required by [email protected]
npm ERR! missing: content-type@~1.0.1, required by [email protected]
npm ERR! missing: depd@~1.0.1, required by [email protected]
npm ERR! missing: [email protected], required by [email protected]
npm ERR! missing: on-finished@~2.2.1, required by [email protected]
npm ERR! missing: [email protected], required by [email protected]
npm ERR! missing: raw-body@~2.0.1, required by [email protected]
npm ERR! missing: type-is@~1.6.2, required by [email protected]
[cabox@box-codeanywhere npmtest]$ npm install lodash npm WARN package.json kidsit@1.0.0 No repository field. npm WARN package.json kidsit@1.0.0 No README data lodash@3.9.3 node_modules/lodash [cabox@box-codeanywhere npmtest]$ ls node_modules/ lodash [cabox@box-codeanywhere npmtest]$ npm ls kidsit@1.0.0 /home/cabox/workspace/npmtest └── lodash@3.9.3 extraneous npm ERR! extraneous: lodash@3.9.3 /home/cabox/workspace/npmtest/node_modules/lodash [cabox@box-codeanywhere npmtest]$ npm prune npm WARN package.json kidsit@1.0.0 No repository field. npm WARN package.json kidsit@1.0.0 No README data unbuild lodash@3.9.3 [cabox@box-codeanywhere npmtest]$ npm ls kidsit@1.0.0 /home/cabox/workspace/npmtest └── (empty)
[cabox@box-codeanywhere npmtest]$ npm ls -g --depth=0 /home/cabox/npm-global/lib ├── gulp@3.9.0 └── npm@2.11.1 [cabox@box-codeanywhere npmtest]$ npm uninstall -g gulp unbuild gulp@3.9.0 [cabox@box-codeanywhere npmtest]$ npm ls -g --depth=0 /home/cabox/npm-global/lib └── npm@2.11.1
[cabox@box-codeanywhere npmtest]$ npm adduser Username: kidsit Password: Email: (this IS public) 1372921435@qq.com [cabox@box-codeanywhere npmtest]$ npm config ls ; cli configs user-agent = "npm/2.11.1 node/v0.10.28 linux x64" ; userconfig /home/cabox/.npmrc prefix = "/home/cabox/npm-global" ; node bin location = /usr/bin/node ; cwd = /home/cabox/workspace/npmtest ; HOME = /home/cabox ; 'npm config ls -l' to show all defaults. [cabox@box-codeanywhere npmtest]$ npm publish + kidsit@0.0.1 [cabox@box-codeanywhere npmtest]$
http://blog.izs.me/post/1675072029/10-cool-things-you-probably-didnt-realize-npm
var utils = require( "utils" ); 上面的require命令将导致node按照以下顺序查找文件,注意不一定是index.js,这个由package.json中的main定义决定的 ./node_modules/utils.js ./node_modules/utils/index.js ./node_modules/utils/package.json
具体参考http://www.bennadel.com/blog/2169-where-does-node-js-and-require-look-for-modules.htm
info unbuild /home/nicholas/share/node_modules/yuitest verbose link symlinking /usr/local/lib/node_modules/yuitest to /home/nicholas/share/node_modules/yuitest ERR! Error: EPROTO, Protocol error '/usr/local/lib/node_modules/yuitest'
Error: EPERM, operation not permitted 'C:\...\noam\node_modules\phantomjs\tmp\phantomjs-1.7.0-windows' at Object.fs.renameSync (fs.js:439:18)
npm config set msvs_version 2012 --global
有时我们希望看清楚一个模块到底是因为谁被安装进来的,也就是说它是哪个package的依赖,你可以使用npm ll命令:
比如下面的命令npm -- gulp-less命令你就可以看出,原来gulp-less这个模块在laravel-elixir模块中包含而安装的,也就是说laravel-elixir已经包含了less预处理功能!
$ npm ll gulp-less laravel-elixir@5.0.0 │ C:\Users\Administrator\devenvironment\Code\newkidsitfromscratch\node_modules\laravel-elixir │ Laravel Elixir Core │ git+https://github.com/laravel/elixir.git │ https://github.com/laravel/elixir └── gulp-less@3.1.0 Less for Gulp git://github.com/plus3network/gulp-less.git https://github.com/plus3network/gulp-less#readme
https://github.com/substack/stream-handbook
参考这篇 https://github.com/felixrieseberg/npm-windows-upgrade 文章,写的非常详细,强烈建议升级到npm3,一些怪异的npm模块安装问题都会没有了!
fsevents: AttributeError: 'MSVSProject' object has no attribute 'iteritems'
上述錯誤的原因是windows机器上没有安装build tooling依赖,解决办法是:
npm install --global --production windows-build-tools
参考: https://github.com/nodejs/node-gyp
version=1 npm run build -- homepage
上面我们的build脚本就可以得到version和homepage这个参数
https://jurosh.com/blog/npm-pass-parameters-into-script
https://github.com/Silviu-Marian/node-codein
通常,如果使用-g参数则安装的nodejs module保存在{prefix}/lib/node_modules 目录中,对应的可执行文件在{prefix}/bin中, {prefix}/share/man中则保存帮助文件信息
如果不使用-g参数,则直接安装在./node_modules目录下,而executable则保存在./node_modules/.bin/文件夹下
那么什么时候应该用-g参数,什么时候不用-g参数呢?
1. 如果你安装的node module希望通过 require('modulename')来在你的程序中应用,那么就应该安装在local
2.如果你希望安装一个可以在全局使用的命令行工具,这时就要用-g参数,因为安装的binary文件将在PATH环境变量中可以找到
很多时候,你可能两者都会需要,比如webpack, gulp既有cli,又有lib代码需要在dev环境中使用,这时local和-g都安装一下
我们在安装完成我们的npm模块后,会根据当时的各软件模版版本情况下载合适的版本到本地,而我们知道开源软件版本变化会很快,你今天安装调试ok,明天很有可能就有新的依赖的版本发布,而这时你如果再次执行npm install就有可能下载了不同版本的依赖,很有可能会产生问题!怎么办?一个可行的方案是一旦调试完毕,你使用npm shrinkwrap的命令将你的依赖版本固化下来,这样下次执行npm install时就依然能够得到相同的版本。
1.到你已经安装的dependency目录下执行npm uninstall xxdependency
2.修改你希望的xxdependency版本
3.执行npm install yourmodule
npm ERR! code ELIFECYCLE
可能的原因就是你可能有其他窗口也开了对应的命令
https://stackoverflow.com/questions/27502608/resolving-require-paths-with-webpack
yarn是一个能够替代npm的node包管理替代方案,支持包cache,离线下载(从cache),扁平化目录等有用的功能,速度快,也很稳定。
但是和npm一样存在网速奇慢的问题,我们同样可以通过以下命令来使用淘宝镜像。
这里再次点赞马云同学,作为中国互联网先进的公司,有造福中国开发者的担当和行动!鄙视baidu和腾讯,一个是无良商业公司,百度一下你就上当。另一个是游戏发家,毒害孩子心灵,但是他们俩个却没有为中国开发者造福,没有为中国互联网的进步做出什么应该有的贡献
yarn config set registry https://registry.npm.taobao.org
https://yarnpkg.com/zh-Hans/docs/usage
https://support.microsoft.com/zh-cn/help/320081/you-cannot-delete-a-file-or-a-folder-on-an-ntfs-file-system-volume
在webpack的build中,我们往往借助npm run script来调用对应的构建方法,这时我们可能希望传入自己的参数,怎么办呢?
npm run[-- ] npm run build -- one two=three four // 等同于 node build.js one two=three four // 这时传入的所有参数都在process.argv中,其值如下,可以在build.js中访问 0: node 1: build.js 2: one 3: two=three 4: four
$ npm info bootstrap versions [ '0.0.1', '0.0.2', '3.1.1', '3.2.0', '3.3.0', '3.3.1', '3.3.2', '3.3.4', '3.3.5', '3.3.6', '3.3.7', '4.0.0-alpha.2', '4.0.0-alpha.3', '4.0.0-alpha.4', '4.0.0-alpha.5', '4.0.0-alpha.6', '4.0.0-beta', '4.0.0-beta.2', '4.0.0-beta.3', '4.0.0' ] $ npm install --save [email protected] √ All packages installed (1 packages installed from npm registry, use 2s, speed 243.93kB/s, json 1(2.48kB), tarball 568.8kB)