Learn JavaScript in Construct, part 12: Modules

15

Index

Features on these Courses

Attached Files

The following files have been attached to this tutorial:

.c3p

modules-template.c3p

Download now 47.07 KB
.c3p

imports-for-events.c3p

Download now 47.58 KB

Stats

8,082 visits, 18,808 views

Tools

Translations

This tutorial hasn't been translated.

License

This tutorial is licensed under CC BY-NC 4.0. Please refer to the license text if you wish to reuse, share or remix the content contained within this tutorial.

Published on 10 Dec, 2021. Last updated 16 Dec, 2021

This is part 12 of the tutorial series Learn JavaScript in Construct. This part continues on from part 11. So in case you missed it, see Learn JavaScript in Construct, part 11: Construct APIs.

We've covered a lot of the language basics of JavaScript in this guide, as well as a range of built-in features in the language, in the browser, and in Construct too. We're now coming towards the end of this guide, and there is only one last major topic to cover: modules. Once again there is a lot that we could potentially cover here, but we'll introduce the concept, cover the fundamentals, and also describe some aspects that are unique to Construct. In particular since scripts in event sheets are a concept unique to Construct, there's a specific way of dealing with that.

Modules

Remember that top-level variables and functions are scoped to the file. That means you can use them anywhere in that script file, but not in another script file.

One way to use things across files is to make them global, adding them as properties of globalThis. However this has a number of problems. It quickly becomes disorganised, as you can end up with hundreds or even thousands of functions all in a single place. Further, it can cause name collisions: if you want to use two different libraries and they both try to define a global function with the same name, one will overwrite the other, and it will probably break things.

Modules solve these problems by providing a clean and organised interface for sharing things between JavaScript files. Each file is a self-contained module - its top-level variables and functions cannot be accessed outside the file. Another way of saying that is its contents are private to the module. If you want to expose something to be used outside of the file, it must be exported with the export keyword. Then another file must import it with the import keyword.

A simple export

For this example let's use a new empty project with two script files: main.js and mymodule.js. We'll export something from mymodule.js and use it in main.js. Download and open the project file below for this example.

.C3P

modules-template.c3p

Download now 47.07 KB

Open the file mymodule.js. Add the function below that just returns a string.

function GetMessage()
{
	return "Hello world from mymodule.js!";
}

Currently this function cannot be used outside of this file. However if we add the export keyword, it becomes available to other files for importing. This goes at the start of the function, as shown below.

export function GetMessage()
{
	return "Hello world from mymodule.js!";
}

Script files can export as many things as they want. In this case we're just exporting a single function.

Now open main.js. We want to call GetMessage(), but it's still not available yet. To import everything from mymodule.js, add the following line:

import * as MyModule from "./mymodule.js";

The * means "everything", as MyModule means to put everything in an object named MyModule, and from "./mymodule.js" indicates which file to load. So overall this means "import everything to an object named MyModule from mymodule.js".

Now everything exported from mymodule.js is in an object named MyModule. So our GetMessage() function can be called with MyModule.GetMessage(). Try the following code below for main.js which logs the message to the console.

import * as MyModule from "./mymodule.js";

console.log(MyModule.GetMessage());

Preview the project and check the browser console, and you should see the message appear!

Congratulations - you've got your first import working.

  • 1 Comments

  • Order by
Want to leave a comment? Login or Register an account!
  • This clears so many confusions, still hope to see more tutorials on how to use the javascript and even sheet together.