Reputation: 47
I'm trying to use the library videojs-abloop
My nodejs version is v12.18.3
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'
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" }
I checked about the ESM imports but Node.js 12 : ESM Imports, but I think it is not related to this problem
Upvotes: 3
Views: 15785
Reputation: 1972
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) {
Upvotes: 0
Reputation: 369526
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 parentpackage.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 viaSTDIN
, 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
.
Upvotes: 4