简体   繁体   中英

NodeJS 12 SyntaxError: Unexpected token 'export'

What I'm trying to do

I'm trying to use the library videojs-abloop

My nodejs version is v12.18.3

What is the problem

First I installed two libraries as asked from videojs-abloop :

npm install video.js videojs-abloop

Then ran the command

$ node --experimental-modules index.js

Error output

$ node --experimental-modules index.js
(node:31057) ExperimentalWarning: The ESM module loader is experimental.
/my_path/testimport/node_modules/videojs-abloop/videojs-abloop.js:8
export default function (window, videojs) {
^^^^^^

SyntaxError: Unexpected token 'export'

What is my project structure

I two files: index.js and package.json :

index.js

import videojs from 'video.js'
import abLoopPlugin from 'videojs-abloop'

abLoopPlugin(window,videojs);

package.json

{ "type": "module" }

What I have checked

I checked about the ESM imports but Node.js 12: ESM Imports , but I think it is not related to this problem

It is impossible to tell just from looking at a file whether it is an ECMAScript Script or an ECMAScript Module. Therefore, you need to tell the engine which of the two it is.

On the web, this is solved via different MIME Types, but MIME Types don't exist on filesystems, so Node.js uses the file extension ( .mjs ) or the type field in package.json ( "type": "module" ) to distinguish between the two.

As the documentation says [Note: I am quoting from the latest docs, but the only difference is whether ESM are enabled by default or not]:

Enabling

Experimental support for ECMAScript modules is enabled by default. Node.js will treat the following as ES modules when passed to node as the initial input, or when referenced by import statements within ES module code:

  • Files ending in .mjs .
  • Files ending in .js when the nearest parent package.json file contains a top-level field "type" with a value of "module" .
  • Strings passed in as an argument to --eval , or piped to node via STDIN , with the flag --input-type=module .

There are several pages more about how exactly Node.js determines whether a file is an ECMAScript Script or an ECMAScript Module.

You seem to have an outdated or somehow broken version of videojs-abloop . According to the GitHub Issues , and particularly this commit , videojs-abloop is written as an ECMAScript Module but is transpiled to an ECMAScript Script. In your case, for some reason, you have an ECMAScript Module instead of an ECMAScript Script of videojs-abloop .

I've published an update to videojs-abloop (version 1.2.0) which reverts to exporting the plugin using Common JS. This seems to work, either using require to import the modules, or with "type":"module" or --experimental-modules set and import used.

I recreated your issue using your code, then applied the update and the issue went away.

Please update to v1.2.0 and let me know if it works (issues via https://github.com/phhu/videojs-abloop/issues )

Thanks for posting the problem, and sorry for the oversight!

To make the change manually, just change the first line non-comment line of node_modules/videojs-ablooop/videojs-abloop.js to

module.exports = function (window, videojs) {

The technical post webpages of this site follow the CC BY-SA 4.0 protocol. If you need to reprint, please indicate the site URL or the original address.Any question please contact:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM