javascript - import过来exports的内容 为什么是undefined

查看:89
本文介绍了javascript - import过来exports的内容 为什么是undefined的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

问 题

a.js

const typeList = [
    {a:1}, 
    {b:2}, 
    {c:3}
]

exports = {typeList}

b.js

import { typeList } from './a'
console.log(typeList) // =====> 显示undefined,为什么?

解决方案

前面几位说的是让你怎么改,但是没告诉为什么,我来解释下。

exports是一个引用变量,它其实是module.exports的一个简写。

如果你对外暴漏变量,你这么写没问题:

exports.something = ref;

但是如果你做了替换:

exports = {...};

你要知道,node内部对外引用的是modle.exports,你改变的只是一个局部引用,而不是真实的引用,这个涉及脚本的对象引用规则,简单来说,大概是这样:

var module = {exports: [1,2,3]};
var exports = module.exports;
console.log(module.exports === exports);

// if you do:
exports = {...};

// but you know...
console.log(module.exports);

所以其实如果你再勤快点,改写成下面这样就OK了:

module.exports = {...};

PS: exports是es5的语法,export是es6的语法,楼上很多人弄混了。

这篇关于javascript - import过来exports的内容 为什么是undefined的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆