安装cheerio时,npm can't find package.json

Vagor
  • 716

我在安装cheerio的时候,系统报错如下。


taolinweideMacBook-Pro:http Vagor$ npm install cheerio
/Users/Vagor
└── cheerio@0.19.0 

npm WARN ENOENT ENOENT: no such file or directory, open '/Users/Vagor/package.json'
npm WARN EPACKAGEJSON /Users/Vagor No description
npm WARN EPACKAGEJSON /Users/Vagor No repository field.
npm WARN EPACKAGEJSON /Users/Vagor No README data
npm WARN EPACKAGEJSON /Users/Vagor No license field.
taolinweideMacBook-Pro:http Vagor$ 

我想请教一下各位几个问题:

  1. 怎么解决如上问题

  2. 能否给我讲解一下这其间的原理

我在网上找到了关于package.json的内容,附上链接,以便大家查阅

包(package)

我们已经知道了JS模块的基本单位是单个JS文件,但复杂些的模块往往由多个子模块组成。为了便于管理和使用,我们可以把由多个子模块组成的大模块称做包,并把所有子模块放在同一个目录里。

在组成一个包的所有子模块中,需要有一个入口模块,入口模块的导出对象被作为包的导出对象。例如有以下目录结构。

/home/user/lib/
    cat/
        head.js
        body.js
        main.js 

其中cat目录定义了一个包,其中包含了3个子模块。main.js作为入口模块,其内容如下:

var head = require('./head'); 
var body = require('./body');

exports.create = function (name) {
    return {
        name: name,
        head: head.create(),
        body: body.create()
    }; };

在其它模块里使用包的时候,需要加载包的入口模块。接着上例,使用require('/home/user/lib/cat/main')能达到目的,但是入口模块名称出现在路径里看上去不是个好主意。因此我们需要做点额外的工作,让包使用起来更像是单个模块。

index.js

当模块的文件名是index.js,加载模块时可以使用模块所在目录的路径代替模块文件路径,因此接着上例,以下两条语句等价。

var cat = require('/home/user/lib/cat'); 
var cat = require('/home/user/lib/cat/index');

这样处理后,就只需要把包目录路径传递给require函数,感觉上整个目录被当作单个模块使用,更有整体感。

package.json

如果想自定义入口模块的文件名和存放位置,就需要在包目录下包含一个package.json文件,并在其中指定入口模块的路径。上例中的cat模块可以重构如下。

/home/user/lib/
     cat/
         doc/
         lib/
            head.js
            body.js
            main.js
         tests/

package.json 其中package.json内容如下。

"name": "cat",
"main": "./lib/main.js" 

如此一来,就同样可以使用require('/home/user/lib/cat')的方式加载模块。NodeJS会根据包目录下的package.json找到入口模块所在位置。

回复
阅读 13.7k
2 个回答
沼泽
  • 890
✓ 已被采纳

你可以先用npm init初始化生成package.json文件,再进行npm i cheerio --save-dev来安装模块

试试

npm install -g npm-autoinit
npm config set onload-script npm-autoinit/autoinit

同类问题

sudo npm install cheerio 试试

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
宣传栏