最佳答案
我不明白为什么这些琐碎的代码不起作用:
.html:
<!doctype HTML>
<html>
<head>
<script type="module" src="/showImport.js"></script>
</head>
<body>
<button onclick="showImportedMessage();">Show Message</button>
</body>
</html>
ShowImport. js:
import showMessage from '/show.js';
function showImportedMessage() {
showMessage();
}
Show.js:
export default "Why do I need this?";
export function showMessage() {
alert("Hello!");
}
当我连接 Chrome (v65)时,我看到以下错误
(index):8 Uncaught ReferenceError: showImportedMessage is not defined
at HTMLButtonElement.onclick ((index):8)
onclick @ (index):8
如果我去掉了 type=module
(并且通过将 showMessage
函数放在 showImport.js
中来导入/导出) ,那么一切都可以正常工作,但是 这样做的全部目的是使用模块不行。
此外,我不得不补充一句无用的 export default
语句,如果没有它,Chrome 会抱怨:
Uncaught SyntaxError: The requested module '/show.js' does not provide an export named 'default'
我错过了什么?