15
当我玩弄Babel和Webpack时,我偶然发现了一些非常奇怪的行为。在调试器中未定义ES6模块导入
我在我的main.js
中投掷了一个调试器,看看我是否正确导入,但Chrome的控制台不停地大声说我试图导入的模块没有定义。我尝试控制台记录相同的模块,而我看到它打印到我的控制台。
什么给?我已经粘贴了以下相关的代码片段:
main.js
import Thing from './Thing.js';
debugger // if you type Thing into the console, it is not defined
console.log(new Thing()); // if you let the script finish running, this works
thing.js
class Thing {
}
export default Thing;
webpack.config.js
var path = require('path');
module.exports = {
entry: './js/main.js',
output: {
path: __dirname,
filename: 'bundle.js'
},
module: {
loaders: [
{ test: path.join(__dirname, 'js'), loader: 'babel-loader' }
]
}
};
太棒了,感谢您的快速回复!我想知道是否打开源地图会改变这种行为..? – Salar
使调试器无用是一个相当大的国际海事组织,我觉得很难相信巴别尔会允许 – Salar