zoukankan      html  css  js  c++  java
  • webpack打包优化

    vue-cli3 webpack优化

    . 开启Gzip压缩

    vue.config.js

    webpack配置

    安装包
    npm install compression-webpack-plugin -D

    const CompressionWebpackPlugin = require('compression-webpack-plugin')
    
    module.exports = { 
    
      configureWebpack: config => {
    
        // 开发环境不需要gzip
        if (process.env.NODE_ENV !== 'production') return
    
        config.plugins.push(
    
          new CompressionWebpackPlugin({
    
            // 正在匹配需要压缩的文件后缀
    
            test: /.(js|css|svg|woff|ttf|json|html)$/,
    
            // 大于10kb的会压缩
    
            threshold: 10240,
    
            // 其余配置查看compression-webpack-plugin
          })
        )
      }
    }
    

    服务端配置 开启gzip

    添加gzip_static on; #静态压缩

    
     location / {
    
          root /med/dist;
    
          index /index.html;
    
          try_files $uri $uri/ /index.html;
    
          gzip_static on; #静态压缩
    
      }
    
    }
    
    

    .组件按需加载

    elementUI

    安装

    
    npm install babel-preset-env -D
    
    npm install babel-plugin-component -D
    
    

    babel.config.js

    
      plugins: [
    
        [
          'component',
    
          {
            'libraryName': 'element-ui',
    
            'styleLibraryName': 'theme-chalk'
    
          }
    
        ]
    
      ]
    
    

    main.js 按需引入

    
    import Vue from 'vue';
    
    import {
      Dialog,
      Input,
      Button,
      Table,
      TableColumn,
      Tooltip,
      ...
      Loading,
      Message,
    } from 'element-ui';
    
    
    Vue.use(Dialog);
    
    Vue.use(Input);
    
    Vue.use(Button);
    
    Vue.use(Table);
    
    Vue.use(TableColumn);
    
    Vue.use(Tooltip);
    
    ...
    
    Vue.use(Loading.directive);
    
    
    Vue.prototype.$loading = Loading.service;
    
    Vue.prototype.$message = Message;
    
    

    路由懒加载

        
        {
              name: 'collectioner_video_list',
    
              path: 'ownerOrder',
    
              // component: ownerOrder,
    
               component: resolve => require(['@/pages/moniterCenter/ownerOrder'], resolve),
    
               meta: {
    
                     requiresAuth: true
    
              }
    
         }
    
  • 相关阅读:
    Release和Debug的区别[转]
    SVM运用到多分类[引]
    HMM
    [转] 数据挖掘 机器学习 模式识别的关系
    [转]mysql 数据导入
    java 获取当前时间戳
    二叉树遍历建树[zhuan]
    关于c指针[转]
    词法分析
    组合数据类型练习,综合练习
  • 原文地址:https://www.cnblogs.com/goddess/p/12088138.html
Copyright © 2011-2022 走看看