This is my seventh day of the Gwen Challenge
The AMD specification is one of the best known, and stands for Asynchronous Module Definition.
From its specification page, AMD is short and simple, but it fully describes module definitions, dependencies, references, and loading mechanisms.
1. What is AMD?
As a specification, you define its syntax API, not its implementation.
The AMD specification is simple to a single API, define function, syntax is as follows:
define([module-name? ] , [array-of-dependencies?], [module-factory-or-object]);
Copy the code
-
Module-name: indicates the module id, which can be omitted.
-
Array-of-dependencies: indicates the module on which it depends. You can omit it.
-
Module-factory-or-object: An implementation of a module or a JavaScript object.
The define function AMD has A: Asynchronous. When define is executed,
Step 1: The dependency modules listed in the second parameter will be called asynchronously,
Step 2: After all modules have been loaded,
Step 3: Execute if the third argument is a callback function, and then tell the system that the module is available, thus notifying the dependent module that it is available.
For server-side AMD such as NodeJs, module loading does not block the server process, which also improves performance.
2.AMD example: How to define a module
define('alpha'['require'.'exports'.'beta'].function (require.exports, beta) {
exports.verb = function() {
return beta.verb();
// or :return require(" beta ").verb();}});Copy the code
Defines an alpha module and relies on the built-in Require, exports module and external beta module. As you can see, the third argument is the callback function, and you can use the dependent modules directly, which are provided as arguments to the callback function in the dependency declaration order.
-
The require function allows you to rely on a module at any time, taking a reference to the module so that it can be used even if the module is not defined as a parameter.
-
Exports is the entity of the defined alpha module, on which any properties and methods defined are also alpha module properties and methods. Exports.verb =… The verb method is defined for the alpha module. In this example, the verb method of module beta is simply called.
3. Anonymous module
Note: The define method allows you to omit the first parameter, thus defining an anonymous module, in which case the name of the module file is the module identifier.
If the module file is in A. js, then a is the module name. You can use “A” in dependencies to depend on the anonymous module. One benefit of this is that modules are highly reusable. You take an anonymous module, put it anywhere and use it. The module name is its file path. This also fits nicely with the DRY (Don’t Repeat Yourself) principle.
define(['alpha'].function (alpha) {
return {
verb: function(){
return alpha.verb() + 2; }}; });Copy the code
4. Define with only one parameter
As mentioned earlier, the first two parameters of define can be omitted. The third parameter has two cases,
A. A JavaScript object
(1) An object containing a method with a function
(2) Data objects that provide data (very similar to JSONP)
// We named the module file without China.js
define({
provinces: [{name'Shanghai',areas: [' Pudong New Area ', 'Xuhui District']},{nameJiangsu,cities: [' Nanjing ', 'Nantong']}// omit other data. Note that this is a data file]});Copy the code
Assuming the file name is china.js, then if a module needs this data, just (using the anonymous module rule) :
define(['china'].function(china){
// Use Chinese provincial data here
});
Copy the code
In this way, the module is truly highly reusable, either remotely or by copying to a local project, saving development time and maintenance time.
B. A function
If the argument is a function, one of its uses is for rapid development implementations.
define(function(){
var p = require(" China ");// Use the China module
});
Copy the code
For smaller applications, you don’t have to worry ahead of time about what modules you need and who you’ll use them for. In a function, you can require any module you need at any time.
That is, you omit the module name and the module you need to rely on. This doesn’t mean you don’t have to rely on other modules, but it allows you to require them when you need them.
When the define method is executed, it calls the toString method of the function and scans the require call to help you load these modules in advance and execute them when they are finished. This makes rapid development possible. It is important to note that Opera does not support the toString method of functions very well, so it is not very useful in browsers. This won’t be a problem if you package all your JavaScript files with the build tool, which will help you scan require and force the dependent modules to be loaded.
5. To summarize
I don’t think I will touch this knowledge point because it is not necessary for my work. I have been responsible for the back-end code and have not involved the front-end code for a long time. NodeJS doesn’t know much about NodeJS. I prefer to learn systematically, but work doesn’t allow you to waste time, so sometimes it’s just Ctrl+C and Ctrl+V.
The AMD specification was an important attempt at JavaScript development. It unified the module definition and loading mechanism of JavaScript in a simple and elegant way, and was quickly adopted by many frameworks. This is good news for developers, because with AMD we lower the barriers to learning and using various frameworks, and are able to define and use modules in a unified way, improving development efficiency and reducing application maintenance costs.