The following are the practical aspects of the front-end project modularity, including the following:
- Build NPM private Warehouse management source and dependence;
- Use Webpack to package the infrastructure code;
- Writing a reliable class library using TypeScript (in implementation)
This article is about the 2nd part of the front-end project templating
Present situation
The actual project is far more complex than the mygreeting used by the example, such as
- In order to improve maintainability we have broken the project into many functional templates;
- We want to use Promise and other grammar, but scruples about the supporting ability of the target environment;
- May rely on a number of third-party class libraries;
- In order to increase loading speed we need to do a lot of extra work when packing;
- Code compression;
- Tree Shaking (at the end of the text);
- Can be run in a WEB browser, can also be used in NodeJS;
Suppose we have a toolset project Myhammer, which contains the Base64 transformation feature and a simple version of the Dictionary tree implementation, the project structure is as follows:
[email protected] /d/Documents/MyGit/PracticeInNPM/myHammer$ tree src/ test/src/├── base64.js├── index.js└── TrieFilter.jstest/├── base64.test.js└── TrieFilter.test.js0 directories, 5 files
index.js
Exported the functional modules in the project:
const base64 = require('./base64');const TrieFilter = require('./TrieFilter')module.exports = { base64, TrieFilter,}
If not packaged, publishing the current project separately to the NPM warehouse is no problem, just
- Rely on the project when the wording of the more tangled, shaped like
const base64 = require(‘myHammer/src/base64‘)
;
- Possible adaptation issues to the target environment, as described earlier;
- Target environment does not support syntax such as Promise, etc.
- The source code is coffeescript or TypeScript, cannot be quoted directly
Use Webpack below to resolve these issues.
Webpack Packaging base Class Library
Webpack document content, online tutorials are more about application packaging, is now organized as follows.
This article is not a guide to Webpack, only mentions class library packaging, while the Webpack has been updated to version 4.x.
package.json
The nodes that need to be configured package.json
are used by the main
NodeJS environment.
"main": "src/index.js",
The NodeJS runtime environment is agreed upon and require(‘xxx‘)
will be read by the configuration when used.
- Avoid the
require(‘myHammer/src/base64‘)
notation of a similar referential full path
- If the source uses a high version of the language features, you can translate and package the code into
dist/inde-es5.js
a path, and then modify the configuration to point to the file to backward compatibility
- Use the same language you need to translate into JavaScript
When we look for references in some Ides, we often find that function declarations are implemented in a number of places because the code is translated and packaged into many copies, as shown in.
webpack.config.js
The class library package needs to webpack.config.js
output
be configured in the following:
output : { library : "hammer", libraryTarget: "umd", globalObject : "this", path : path.join(__dirname, "dist"), filename : "hammer.js",}
Other configuration please read the document yourself, the full content of the code webpack.config.js.
libraryTarget
: In order to be effective in both the browser and NodeJS environment, use umd
as a target, refer to Output-librarytarget
globalObject
: Use this
the Replace default window
, reference Webpack 4.0.1 | Webworker window is not defined
#6642
As mentioned earlier, without regard to language, version, target platform differences, the source code is published directly to the NPM repository, and then added dependencies and references are no problem. In an increasingly complex business situation, handwritten code eliminates these differences directly at the implementation level, and using Webpack allows us to focus more on the business itself, making life easier.
Publish to NPM and use dependencies
After completing the specific business, we package the project and publish it to the private NPM warehouse
webpack --mode development # 视具体需求npm publish --registry http://ubuntu-17:4873 # --force
In the Mydemo project we add references
yarn add myHammer --registry http://ubuntu-17:4873
Modify the index.js
following:
const myGreeting = require('myGreeting');const {base64} = require('myHammer');(function () { let greeting = myGreeting('Rattz'); console.log(base64.encode(greeting));})();
Run up
$ node index.jsSGVsbG8gUmF0dHo=
About Tree Shaking
Mention a little bit about the tree Shaking, which simply says that tree Shaking can effectively reduce the size of a packaged file by not referencing the code that doesn't depend on it.
For example, we used the ES2016 syntax and wanted to compile it in the ES2015 environment. There are a number of possible options, one of which is
- Use Babel family barrels included
babel-cli, babel-core, babel-loader, babel-preset-env
;
- Add. babelrc file to write content
{"presets":["env"]}
;
- Used in the first line of the ingress code
require(‘babel-polyfill‘);
Babel syntax conversion, patch files for the adaptation of the lower version of ES2015, the scheme babel-polyfill
is fully referenced, the package is completed after the use of about 120k size, often more than the business code.
The tree Shaking is to solve the problem, for example, a template provides addition and subtraction, and we rely only on the addition method, if the packaging tool supports Tree Shaking, it can be packaged to eliminate unused subtraction related code.
Webpack provides support, seen in Tree Shaking-webpack.
The source code used for the project has been released GITHUB,JUSFRW original
Modular practice of front-end Projects 2: Packaging infrastructure Code with Webpack