vue项目打包流程

vue项目打包流程vue 项目打包流程二 打包优化 1 首先在根目录下面创建一个 vue config js 文件 2 去除 map 文件 在 vue config js 文件里面抛出一个对象 然后把下面两段代码写到对象里面 然后在控制台或者终端通过 npmrunbuild 命令 打包项目注 如果一次不行 就在执行一次 module exports 在 vue config js 文件里面抛出一个对象 publicPath productionSo false 不输出 map 文件 3

vue项目打包流程

二、打包优化

1.首先在根目录下面创建一个vue.config.js文件
在这里插入图片描述
2.去除.map文件,在vue.config.js文件里面抛出一个对象,然后把下面两段代码写到对象里面,然后在控制台或者终端通过npm run build命令,打包项目




注:如果一次不行,就在执行一次

module.exports = { 
   }//在vue.config.js文件里面抛出一个对象 
publicPath: "./", productionSourceMap: false, //不输出map文件 

在这里插入图片描述
3.开启CDN加速,把下面这段代码写到vue.config.js这个文件里面,切记要写到module.exports = {}这个对象上面

/ 是否为生产环境 const isProduction = process.env.NODE_ENV !== 'development'; // 本地环境是否需要使用cdn const devNeedCdn = false // cdn链接 const cdn = { 
    // cdn:模块名称和模块作用域命名(对应window里面挂载的变量名称) externals: { 
    vue: 'Vue', vuex: 'Vuex', 'vue-router': 'VueRouter', 'marked': 'marked', 'highlight.js': 'hljs', 'nprogress': 'NProgress', 'axios': 'axios' }, // cdn的css链接 css: [ ], // cdn的js链接 js: [ 'https://cdn.bootcss.com/vue/2.6.10/vue.min.js', 'https://cdn.bootcss.com/vuex/3.1.2/vuex.min.js', 'https://cdn.bootcss.com/vue-router/3.1.3/vue-router.min.js', 'https://cdn.bootcss.com/axios/0.19.2/axios.min.js' ] } 

在这里插入图片描述

在这里插入图片描述
3.1:在抛出的那个对象module.exports = {}里面写入下面这段代码

chainWebpack: config => { 
    // ============注入cdn start============ config.plugin('html').tap(args => { 
    // 生产环境或本地需要cdn时,才注入cdn if (isProduction || devNeedCdn) args[0].cdn = cdn return args }) // ============注入cdn start============ }, 

在这里插入图片描述
3.2:在public这个文件夹下面,找到index.html这个文件,在title这个标签下面,head头标签里面把下面这段代码复制进去

 <!-- 使用CDNCSS文件 --> <% for (var i in htmlWebpackPlugin.options.cdn &&
    htmlWebpackPlugin.options.cdn.css) { 
    %> <link href="<%= htmlWebpackPlugin.options.cdn.css[i] %>" rel="stylesheet" /> <% } %> <!-- 使用CDNCSS文件 --> <!-- 使用CDNJS文件 --> <% for (var i in htmlWebpackPlugin.options.cdn &&
    htmlWebpackPlugin.options.cdn.js) { 
    %> <script src="<%= htmlWebpackPlugin.options.cdn.js[i] %>"></script> <% } %> <!-- 使用CDNJS文件 --> 

在这里插入图片描述
3.3:上面这些操作步骤就是开始CDN加速的流程,把上面这些步骤操作完以后,我们继续在控制台输入npm run build这个命令,继续打包,打包完成以后在你的文件夹里面应该会有一个dist这个文件,这个文件就是打包后的文件,你可以鼠标右键,点击属性,就可以看到他的体积已经变小啦
在这里插入图片描述
在这里插入图片描述
4.我们继续执行下面的步骤








代码压缩:

4.1:首先我们先在控制台安装命令:npm i -D uglifyjs-webpack-plugin

4.2.然后把下面这段代码写到vue.config.js这个文件里面,这段代码也是要写到抛出的那个对象外面,不能写到抛出的对象里面

const UglifyJsPlugin = require('uglifyjs-webpack-plugin') 

4.3:接着我们把下面的代码写到configureWebpack这个对象里面,写完以后继续执行npm run build命令,继续打包,打包完成以后再dist这个文件夹里面有个index.html,然后双击打开它,看项目是否能跑起来

 // 代码压缩 config.plugins.push( new UglifyJsPlugin({ 
    uglifyOptions: { 
    //生产环境自动删除console compress: { 
    drop_debugger: true, drop_console: true, pure_funcs: ['console.log'] } }, sourceMap: false, parallel: true }) ) 

在这里插入图片描述
5.接着操作公共代码抽离,还是在configureWebpack这个对象里面继续往下写

// 公共代码抽离 config.optimization = { 
    splitChunks: { 
    cacheGroups: { 
    vendor: { 
    chunks: 'all', test: /node_modules/, name: 'vendor', minChunks: 1, maxInitialRequests: 5, minSize: 0, priority: 100 }, common: { 
    chunks: 'all', test: /[\\/]src[\\/]js[\\/]/, name: 'common', minChunks: 2, maxInitialRequests: 5, minSize: 0, priority: 60 }, styles: { 
    name: 'styles', test: /\.(sa|sc|c)ss$/, chunks: 'all', enforce: true }, runtimeChunk: { 
    name: 'manifest' } } } } 

6.骨架屏

  • 先安装npm install vue-skeleton-webpack-plugin这个命令
  • 然后在src这个文件夹下面创建一个Skeleton文件夹,这个名字可以自定义,在这个文件夹下面创建两个文件,index.jsindex.vue这个两个文件

index.js里面写入下面代码

import Vue from 'vue' import Skeleton from './index.vue' export default new Vue({ 
    components: { 
    Skeleton }, template: ' 
   ' }) 

index.vue里面写入:

<template> <div class="skeleton-wrapper"> <header class="skeleton-header"></header> <section class="skeleton-block"> <img src="data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHhtbG5zOnhsaW5rPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5L3hsaW5rIiB2aWV3Qm94PSIwIDAgMTA4MCAyNjEiPjxkZWZzPjxwYXRoIGlkPSJiIiBkPSJNMCAwaDEwODB2MjYwSDB6Ii8+PGZpbHRlciBpZD0iYSIgd2lkdGg9IjIwMCUiIGhlaWdodD0iMjAwJSIgeD0iLTUwJSIgeT0iLTUwJSIgZmlsdGVyVW5pdHM9Im9iamVjdEJvdW5kaW5nQm94Ij48ZmVPZmZzZXQgZHk9Ii0xIiBpbj0iU291cmNlQWxwaGEiIHJlc3VsdD0ic2hhZG93T2Zmc2V0T3V0ZXIxIi8+PGZlQ29sb3JNYXRyaXggaW49InNoYWRvd09mZnNldE91dGVyMSIgdmFsdWVzPSIwIDAgMCAwIDAuOTMzMzMzMzMzIDAgMCAwIDAgMC45MzMzMzMzMzMgMCAwIDAgMCAwLjkzMzMzMzMzMyAwIDAgMCAxIDAiLz48L2ZpbHRlcj48L2RlZnM+PGcgZmlsbD0ibm9uZSIgZmlsbC1ydWxlPSJldmVub2RkIiB0cmFuc2Zvcm09InRyYW5zbGF0ZSgwIDEpIj48dXNlIGZpbGw9IiMwMDAiIGZpbHRlcj0idXJsKCNhKSIgeGxpbms6aHJlZj0iI2IiLz48dXNlIGZpbGw9IiNGRkYiIHhsaW5rOmhyZWY9IiNiIi8+PHBhdGggZmlsbD0iI0Y2RjZGNiIgZD0iTTIzMCA0NGg1MzN2NDZIMjMweiIvPjxyZWN0IHdpZHRoPSIxNzIiIGhlaWdodD0iMTcyIiB4PSIzMCIgeT0iNDQiIGZpbGw9IiNGNkY2RjYiIHJ4PSI0Ii8+PHBhdGggZmlsbD0iI0Y2RjZGNiIgZD0iTTIzMCAxMThoMzY5djMwSDIzMHpNMjMwIDE4MmgzMjN2MzBIMjMwek04MTIgMTE1aDIzOHYzOUg4MTJ6TTgwOCAxODRoMjQydjMwSDgwOHpNOTE3IDQ4aDEzM3YzN0g5MTd6Ii8+PC9nPjwvc3ZnPg=="> <img src="data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHhtbG5zOnhsaW5rPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5L3hsaW5rIiB2aWV3Qm94PSIwIDAgMTA4MCAyNjEiPjxkZWZzPjxwYXRoIGlkPSJiIiBkPSJNMCAwaDEwODB2MjYwSDB6Ii8+PGZpbHRlciBpZD0iYSIgd2lkdGg9IjIwMCUiIGhlaWdodD0iMjAwJSIgeD0iLTUwJSIgeT0iLTUwJSIgZmlsdGVyVW5pdHM9Im9iamVjdEJvdW5kaW5nQm94Ij48ZmVPZmZzZXQgZHk9Ii0xIiBpbj0iU291cmNlQWxwaGEiIHJlc3VsdD0ic2hhZG93T2Zmc2V0T3V0ZXIxIi8+PGZlQ29sb3JNYXRyaXggaW49InNoYWRvd09mZnNldE91dGVyMSIgdmFsdWVzPSIwIDAgMCAwIDAuOTMzMzMzMzMzIDAgMCAwIDAgMC45MzMzMzMzMzMgMCAwIDAgMCAwLjkzMzMzMzMzMyAwIDAgMCAxIDAiLz48L2ZpbHRlcj48L2RlZnM+PGcgZmlsbD0ibm9uZSIgZmlsbC1ydWxlPSJldmVub2RkIiB0cmFuc2Zvcm09InRyYW5zbGF0ZSgwIDEpIj48dXNlIGZpbGw9IiMwMDAiIGZpbHRlcj0idXJsKCNhKSIgeGxpbms6aHJlZj0iI2IiLz48dXNlIGZpbGw9IiNGRkYiIHhsaW5rOmhyZWY9IiNiIi8+PHBhdGggZmlsbD0iI0Y2RjZGNiIgZD0iTTIzMCA0NGg1MzN2NDZIMjMweiIvPjxyZWN0IHdpZHRoPSIxNzIiIGhlaWdodD0iMTcyIiB4PSIzMCIgeT0iNDQiIGZpbGw9IiNGNkY2RjYiIHJ4PSI0Ii8+PHBhdGggZmlsbD0iI0Y2RjZGNiIgZD0iTTIzMCAxMThoMzY5djMwSDIzMHpNMjMwIDE4MmgzMjN2MzBIMjMwek04MTIgMTE1aDIzOHYzOUg4MTJ6TTgwOCAxODRoMjQydjMwSDgwOHpNOTE3IDQ4aDEzM3YzN0g5MTd6Ii8+PC9nPjwvc3ZnPg=="> </section> </div> </template> <script> export default { 
    name: 'skeleton' } </script> <style scoped> .skeleton-header { 
    height: 40px; background: #1976d2; padding:0; margin: 0; width: 100%; } .skeleton-block { 
    display: flex; flex-direction: column; padding-top: 8px; } </style> 

7.下面在vue.config.js写入
注:这段代码写到configureWebpack这个对象里面

config.plugins.push(new SkeletonWebpackPlugin({ 
    webpackConfig: { 
    entry: { 
    app: path.join(__dirname, './src/skeleton/indx.js'), }, }, minimize: true, quiet: true, // 如果不设置那么所有的路由都会共享这个骨架屏组件 router: { 
    mode: 'hash', // 给对应的路由设置对应的骨架屏组件,skeletonId的值根据组件设置的id routes: [ { 
    path: '/home', skeletonId: 'skeleton' } ] }})) 

下面这段代码写到对象外面,不能学到任何的一个对象里面

//骨架屏渲染 const SkeletonWebpackPlugin = require('vue-skeleton-webpack-plugin') //path引入 const path = require('path') 

在这里插入图片描述

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/228635.html原文链接:https://javaforall.net

(0)
上一篇 2026年3月16日 下午6:34
下一篇 2026年3月16日 下午6:34


相关推荐

  • R CRACING电脑版

    R CRACING电脑版

    2026年3月19日
    2
  • Scikit中的特征选择,XGboost进行回归预测,模型优化的实战

    Scikit中的特征选择,XGboost进行回归预测,模型优化的实战前天偶然在一个网站上看到一个数据分析的比赛(sofasofa),自己虽然学习一些关于机器学习的内容,但是并没有在比赛中实践过,于是我带着一种好奇心参加了这次比赛。赛题:足球运动员身价估计比赛概述本比赛为个人练习赛,主要针对于于数据新人进行自我练习、自我提高,与大家切磋。练习赛时限:2018-03-05至2020-03-05任务类…

    2022年4月28日
    57
  • 国产游戏表 (来自游侠)

    国产游戏表 (来自游侠)国产游戏表 来自游侠 2007 年 nbsp nbsp nbsp 游戏名称 nbsp nbsp nbsp 发售日期 nbsp nbsp nbsp 制作方 nbsp nbsp nbsp 发行方 nbsp nbsp nbsp nbsp nbsp nbsp nbsp nbsp nbsp nbsp 天下霸图 2 nbsp nbsp nbsp 2007 年 2 月 15 日 nbsp nbsp nbsp 台湾光谱资讯 nbsp nbsp nbsp 台湾光谱资讯 nbsp nbsp nbsp 武侠经营 nbsp nbsp nbsp nbsp nbsp 幻想三国志 nbsp nbsp nbsp 1 月 23 日 nbsp nbsp nbsp 宇峻奥汀科技 nbsp nbsp nbsp 中视网元 nbsp nbsp nbsp RPG nbsp nbsp nbsp nbsp nbsp 仙剑奇侠传 nbsp nbsp nbsp 8 月 1 日 nbsp nbsp nbsp 上软科技 nbsp nbsp nbsp 寰宇之星 nbsp nbsp nbsp RPG nbsp nbsp

    2026年3月19日
    2
  • mysql的左连接和右连接(内连接和自然连接的区别)

    获取boy、girl表下载地址一、内连接查询innerjoin关键字:innerjoinon语句:select*froma_tableainnerjoinb_tablebona.a_id=b.b_id;说明:组合两个表中的记录,返回关联字段相符的记录,也就是返回两个表的交集(阴影)部分。案例解释:在boy表和girl表中查出…

    2022年4月11日
    61
  • 小白装机进入pe后黑屏:3步快速修复指南

    小白装机进入pe后黑屏:3步快速修复指南

    2026年3月14日
    2
  • React高阶组件

    React高阶组件一 认识高阶组件什么是高阶组件呢 相信很多人都听说过 也用过高阶函数 它们非常相似 所以我们可以先来回顾一下什么是高阶函数 高阶函数的维基百科定义 至少满足以下条件之一 接受一个或多个函数作为输入 输出一个函数 JavaScript 中比较常见的 filter map reduce 都是高阶函数 那么什么是高阶组件呢 高阶组件的英文是 Higher OrderCompone 简称为 HOC 官方的定义 高阶组件是参数为组件 返回值为新组件的函数 我们可以进行如下的解析

    2026年3月20日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号