In the Vue project, in order to improve the performance and shorten the white screen time of the home page (see Web Performance optimization – first screen and white screen time for more details), we can introduce the public library by CDN and compress the resource file.
For details about how to configure CDN and Gzip, check Disable Cache in the Chrome Developer Tool Network:
- Not configured CDN and Gzip: www.fxss.work/authorityRo…
- Configure the CDN but not configured Gzip: www.fxss.work/authorityRo…
- Configure the CDN and Gzip: www.fxss.work/authorityRo…
However, since Gzip compression only has 2 files, so the difference between 2 and 3 is not obvious, but you can also experience my blog: www.fxss.work/vue-blog/, CDN and Gzip have been configured.
CDN configuration in Vue project
Configure externals in the chainWebpack of the vue.config.js configuration file. Externals contains resources that need to use CDN mode.
module.exports = {
...
chainWebpack: config= > {
if (process.env.NODE_ENV === 'production') {
var externals = {
vue: 'Vue'.axios: 'axios'.'element-ui': 'ELEMENT'.'vue-router': 'VueRouter'.vuex: 'Vuex'
}
config.externals(externals)
const cdn = {
css: [
// element-ui css
'https://cdn.bootcdn.net/ajax/libs/element-ui/2.12.0/theme-chalk/index.css'].js: [
// vue
'https://cdn.bootcdn.net/ajax/libs/vue/2.6.10/vue.min.js'.// vue-router
'https://cdn.bootcdn.net/ajax/libs/vue-router/3.1.3/vue-router.min.js'.// vuex
'https://cdn.bootcdn.net/ajax/libs/vuex/3.1.2/vuex.min.js'.// axios
'https://cdn.bootcdn.net/ajax/libs/axios/0.18.0/axios.min.js'.// element-ui js
'https://cdn.bootcdn.net/ajax/libs/element-ui/2.12.0/index.js']}// Inject the CDN into index.html via html-webpack-plugin
config.plugin('html')
.tap(args= > {
args[0].cdn = cdn
return args
})
}
}
...
}
Copy the code
The PRECEDING CDN connection is BootCDN.
Add the following to the head tag of public/index.html:
<% if (process.env.NODE_ENV= = ='production') { %>
<% for(var css of htmlWebpackPlugin.options.cdn.css) { %>
<link rel="stylesheet" href="<%=css%>" as="style">
<%} % >
<% for(var js of htmlWebpackPlugin.options.cdn.js) { %>
<script src="<%=js%>"></script>
<%} % >
<%} % >
Copy the code
All of the above are in a formal environment because the development environment also needs to use Vue Devtools.
Note that the version used in the local development environment must be the same as that in the official environment. You can view the corresponding version numbers in package.json and package-lock.json.
Configuration of Gzip in Vue project
Gzip is configured using the compression-webpack-plugin.
First install:
npm install compression-webpack-plugin --save-dev
Copy the code
Then do the following configuration in vue.config.js:
const CompressionPlugin = require('compression-webpack-plugin')
const productionGzipExtensions = ['js'.'css']
module.exports = {
...
configureWebpack: config= > {
if (process.env.NODE_ENV === 'production') {
// Production environment
config.plugins.push(
new CompressionPlugin({
filename: '[path].gz[query]'.algorithm: 'gzip'.test: new RegExp('\ \. (' + productionGzipExtensions.join('|') + '$'),
threshold: 10240.minRatio: 0.8}}))else {
// Development environment}}... }Copy the code
However, to use the.gz extension of the precompressed file, you need to configure the server. For details about nginx configuration, see nginx Configuration gzip_static.