Security News
Opengrep Emerges as Open Source Alternative Amid Semgrep Licensing Controversy
Opengrep forks Semgrep to preserve open source SAST in response to controversial licensing changes.
@open-wc/building-webpack
Advanced tools
Part of Open Web Component Recommendation open-wc
Open Web Components provides a set of defaults, recommendations and tools to help facilitate your web component project. Our recommendations include: developing, linting, testing, tooling, demoing, publishing and automating.
We provide default configuration to help you get started building your web component project with webpack.
To set up the default configuration manually:
npm i -D @open-wc/webpack webpack webpack-dev-server http-server
webpack.config.js
:const path = require('path');
const defaultConfig = require('@open-wc/webpack/default-config');
module.exports = defaultConfig();
package.json
:{
"scripts": {
"start": "webpack-dev-server --mode development --open",
"start:es5": "webpack-dev-server --mode development --es5",
"start:build": "http-server dist/ -o",
"build": "webpack --mode production",
"build:stats": "webpack --mode production --profile --json > bundle-stats.json"
}
}
start
runs your app with auto reload for development, it only works on browsers which support modules for faster buildsstart:es5
runs your app for development, it only works on browsers that don't support modules (IE11)build
builds your app for production and outputs it in the /dist
folderstart:build
runs your built app using a plain web server, to prove it works without magic :)build:stats
creates an analysis report of your app bundle to be consumed by Webpack Visualizer and Analyserindex.html
:<!doctype html>
<html>
<head></head>
<body>
<your-app></your-app>
</body>
</html>
index.js
which kickstarts your JS code.
For older browser we need to load the web component polyfills. We use the polyfills-loader for that:import loadPolyfills from '@open-wc/polyfills-loader';
loadPolyfills().then(() => {
import('./my-app.js');
});
You can change the default index.html
and index.js
files:
module.exports = defaultConfig({
indexHTML: path.resolve(__dirname, './src/index.html'),
indexJS: path.resolve(__dirname, './src/index.js'),
});
This lets you use bare imports: import { bar } from 'foo'
instead of import { bar } from '../node_modules/foo/foo.js'
Based on package.json
it selects the most optimal type of module format. es modules and es2015 code is preferred, but it falls back to support other module types such as CommonJS and UMD. These can be a useful way to get done writing code today, but these are not future proof formats. We recommend using es modules as much as possible.
JS is minified for performance. HTML, CSS and is minified when they are used in combination with the html
and css
template tags from lit-html
and lit-element
.
Using webpack-babel-multi-target-plugin, our build outputs an es5 and es2015 version of your app. Using the nomodule
trick, we can serve es2015 code on modern browsers and es5 on older browsers (IE11 mostly). This significantly reduces the size of your app on modern browsers.
Read more about this trick at Jakes blog post "ECMAScript modules in browsers".
By default, babel's compilation of async functions and for of
loops using an expensive transform and runtime. A lot of runtime code is added, and a lot of boilerplate code is added in the transform.
For async functions we use the fast-async plugin instead.
Language polyfills are added based on browser support and usage. This leads to a significantly smaller initial bundle of your app.
Our config only supports standard javascript syntax and browser APIs. We support stage 3 proposals when they add significant value and are easy to support without performance penalties.
Supported proposals:
The default-config
function outputs a regular webpack config, it can easily be extended using webpack-merge
. For example to add an extra entry file and sass loader:
const path = require('path');
const merge = require('webpack-merge');
const createDefaultConfig = require('@open-wc/webpack/default-config');
const defaultConfig = createDefaultConfig();
module.exports = merge(defaultConfig, {
entry: ['additional-entry-file.js'],
module: {
rules: [
{
test: /\.scss$/,
use: [
"style-loader",
"css-loader",
"sass-loader"
]
},
],
},
});
We recommend extending the config only to make small additions. If your configuration deviates too much from our default setup, simply copy paste what we have and use it as a starting point. It will keep your configuration easier to understand.
FAQs
Default configuration for working with webpack
The npm package @open-wc/building-webpack receives a total of 342 weekly downloads. As such, @open-wc/building-webpack popularity was classified as not popular.
We found that @open-wc/building-webpack demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 3 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Opengrep forks Semgrep to preserve open source SAST in response to controversial licensing changes.
Security News
Critics call the Node.js EOL CVE a misuse of the system, sparking debate over CVE standards and the growing noise in vulnerability databases.
Security News
cURL and Go security teams are publicly rejecting CVSS as flawed for assessing vulnerabilities and are calling for more accurate, context-aware approaches.