我试图理解为什么当我解析包含 HTML 的 JSON 响应JSON.parse
时不会失败但会忽略我试图从该端点获取的此类数据http://registry.npmjs.org/core-js
。
这里举个例子。
fetch('http://registry.npmjs.org/core-js').then(response =>
response.json()).then(data => console.log(data));
属性自述文件为空,而如果您在浏览器中加载端点,自述文件将完全填充为:
"readme": "# core-js\n\nModular standard library for JavaScript. Includes polyfills for [ECMAScript 5, 2015, 2016, 2017](https://github.com/zloirock/core-js#ecmascript): [promises](https://github.com/zloirock/core-js#ecmascript-promise), [symbols](https://github.com/zloirock/core-js#ecmascript-symbol), [collections](https://github.com/zloirock/core-js#ecmascript-collections), iterators, [typed ... n\n**It's a global version (first 2 examples), for more info see [`core-js` documentation](https://github.com/zloirock/core-js/blob/v3/README.md).**\n",
但是用JSON.parse
它解析后看起来像这样
如您所见,自述文件是空的。为什么??
仅供参考,我注意到使用 Node.js 的原始问题
body = JSON.parse(body.toString('utf8'));
但是后来我注意到在浏览器中我得到了相同的结果,但是,当自述文件有某种字符、编码或任何似乎默默失败的东西时,它只会发生在某些包中。例如:使用 jquery 可以正常工作。
fetch('http://registry.npmjs.org/jquery').then(response =>
response.json()).then(data => console.log(data));
也许有人知道这里发生了什么。我尝试了许多不同的方法来删除换行符等,但总是得到相同的结果。