JavaScript modules provide a way to structure and organize your code into separate files that can be imported and used in other parts of your application. In this guide, we'll explore how to use JavaScript modules by importing and exporting code snippets.
Creating a Module
A module is a JavaScript file that contains code you want to reuse. To export items from a module, you can use the export
keyword. Here's an example:
math.js
// math.js
export function add(a, b) {
return a + b;
}
export function subtract(a, b) {
return a - b;
}
Importing a Module
To use the code from a module in another file, you can use the import
statement. Here's how to import the add
function from the math.js
module:
main.js
// main.js
import { add } from './math.js';
const result = add(5, 3);
console.log(result); // Outputs: 8
Importing with Aliases
You can use aliases to rename imported items for clarity:
// main.js
import { add as addition } from './math.js';
const result = addition(5, 3);
console.log(result); // Outputs: 8
Importing All Exports
If you want to import all exports from a module, you can use the *
wildcard:
// main.js
import * as mathFunctions from './math.js';
const sum = mathFunctions.add(5, 3);
const difference = mathFunctions.subtract(5, 3);
console.log(sum); // Outputs: 8
console.log(difference); // Outputs: 2
Default Exports
A module can also have a default export. A default export is the fallback value when you import from a module without specifying a name. Here's an example:
greet.js
// greet.js
export default function(name) {
return `Hello, ${name}!`;
}
main.js
// main.js
import greet from './greet.js';
const message = greet('Alice');
console.log(message); // Outputs: 'Hello, Alice!'
Conclusion
JavaScript modules make it easier to organize and reuse your code, allowing you to maintain clean and modular projects. By exporting and importing functions, classes, or variables, you can create a more maintainable and scalable codebase.
Experiment with JavaScript modules in your projects to take advantage of their code organization and reusability benefits.