Why are package imports needed in Meteor

2019-09-09 13:02发布

问题:

About a year ago I have used Meteor, and now I want to use it again, but many things have changed.

When I follow the Blaze tutorial on Meteor.com, they add imports on top of their files:

import { Meteor } from 'meteor/meteor';
import { Template } from 'meteor/templating';
import { ReactiveDict } from 'meteor/reactive-dict';

I got the app working. But when I comment the imports out, the app keeps working like it should work. Why are these imports needed?

I am still using the regular Javascript, not ES6.

Thanks!

回答1:

The import statement is used to import functions, objects or primitives that have been exported from an external module, another script, etc.

The name parameter is the name of the object that will receive the exported members. The member parameters specify individual members, while the name parameter imports all of them. name may also be a function if the module exports a single default parameter rather than a series of members. Below are examples to clarify the syntax.

Import an entire module's contents. This inserts myModule into the current scope, containing all the exported bindings from "my-module.js".

For more detail about the different ways we can use import along with their usage, please check this.



回答2:

They still use the old globals for backwards compatibility. However it is recommended to use the imports so if in some future release they remove the globals your code will still work. You can read more in the appropriate section of the guide.



回答3:

Ok you know import is to import an exported object from another file already.

The point that you may have missed is that MDG heard the need to stop loading everything by default, or at least to provide a mean to control what is loaded in memory and what is not.

Look for the /imports special directory.

Files in that folder are no longer loaded automatically, but only through import statement.

As for the tutorial, I guess they did not explained this functionality, and because it imports only standard functionalities which are still loaded eagerly for backward compatibility, it does not change anything removing those statements.