官术网_书友最值得收藏!

Modules

Modules provide a way to encapsulate your code and create privacy. In object-oriented languages, we usually use classes for this. However, I actually believe that this is an anti-pattern rather than a good practice. Classes should be used where inheritance is desired and not just to structure your code.

I'm sure that you've encountered a lot of different module patterns in JavaScript already. One of the most popular ones that creates privacy using a function closure of an immediately invoked function expression (IIFE) is probably the revealing module pattern. If you'd like to read more about this and maybe other great patterns, I recommend the book Learning JavaScript Design Patterns, by Addy Osmani.

Within ECMAScript 6, we can now use modules to serve this purpose. We simply create one file per module, and then we use the import and export keywords to connect our modules together.

Within the ECMAScript 6 module specification, we can actually export as many things as we like from each module. We can then import these named exports from any other module. We can have one default export per module, which is especially easy to import. Default exports don't need to be named, and we don't need to know their name when importing them:

import SomeModule from './some-module.js'; 
var something = SomeModule.doSomething();
export default something;

There are many combinations on how to use modules. We will discover some of these together while working on our task management application during the upcoming chapters. If you'd like to see more examples on how to use modules, I can recommend the Mozilla Developer Network documentation (https://developer.mozilla.org) on the import and export keywords.

主站蜘蛛池模板: 海南省| 桐柏县| 贵德县| 大连市| 尼木县| 双桥区| 遂川县| 临江市| 岚皋县| 博乐市| 郯城县| 青海省| 枣阳市| 永平县| 永顺县| 东乌珠穆沁旗| 南皮县| 民权县| 屯门区| 淮安市| 桃江县| 民勤县| 翁牛特旗| 长沙市| 嵩明县| 顺义区| 奈曼旗| 肇东市| 海原县| 搜索| 北票市| 静乐县| 海门市| 沁源县| 正宁县| 麻江县| 格尔木市| 北辰区| 阳泉市| 巴东县| 湖口县|