a.js
const typeList = [
{a:1},
{b:2},
{c:3}
]
exports = {typeList}
b.js
import { typeList } from './a'
console.log(typeList) // =====> 显示undefined,为什么?
a.js
const typeList = [
{a:1},
{b:2},
{c:3}
]
exports = {typeList}
b.js
import { typeList } from './a'
console.log(typeList) // =====> 显示undefined,为什么?
13 回答12.8k 阅读
7 回答1.9k 阅读
3 回答1.1k 阅读✓ 已解决
2 回答1.2k 阅读✓ 已解决
6 回答872 阅读✓ 已解决
6 回答1k 阅读
2 回答1.3k 阅读✓ 已解决
前面几位说的是让你怎么改,但是没告诉为什么,我来解释下。
exports是一个引用变量,它其实是module.exports的一个简写。
如果你对外暴漏变量,你这么写没问题:
但是如果你做了替换:
你要知道,node内部对外引用的是modle.exports,你改变的只是一个局部引用,而不是真实的引用,这个涉及脚本的对象引用规则,简单来说,大概是这样:
所以其实如果你再勤快点,改写成下面这样就OK了: