记一次vue项目优化的实例操作

2023-10-26

记一次vue项目优化的实例

项目前端优化是我们经常需要去做的事情,今天我们就来记录下我的实际操作。

一、CDN引入

这是一个常态化的操作了,主要是让我们通过npm下载依赖包和import引入的文件,变成线上使用,减少打包后的文件大小。比如常用的vue、ElementUI、vuex、vue-router、axios等等一些常用的

首先在index.html文件引入

    <!-- 引入样式 -->
    <link rel="stylesheet" href="https://unpkg.com/element-ui/lib/theme-chalk/index.css">
    <script src="https://cdn.jsdelivr.net/npm/vue@2"></script>
    <script src="https://unpkg.com/vue-router@3.0.0/dist/vue-router.js"></script> 
    <script src="https://unpkg.com/vuex@4.0.0/dist/vuex.global.js"></script>
    <!-- 引入组件库 -->
    <script src="https://unpkg.com/element-ui@2.13.2/lib/index.js"></script>

然后注释掉import引入的

在这里插入图片描述

一定要把Vue.use(ElementUI)注释

第三步,找到webpack.base.conf.js文件,在下面添加你CDN引入的依赖

在这里插入图片描述

vuex的store/store.js文件里面修改

在这里插入图片描述

router文件也需要修改

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-Oohqr103-1655281875649)(E:\ljy\资料\img\image-20220518141632833.png)]

坑:

1.一定要先引入vue的,然后再加其他的,不然会报错,找不到elementUI的标签名;

2.不能只引入elementUI,不引入vue,一样会报错;

3.我引入的vue-routerCDN,在抓包的时候发现居然要四点多秒种才下载完成,所以我就去掉了,我不知道你们会不会,可以先试试。

二、gzip压缩

首先安装一个插件

npm install --save-dev compression-webpack-plugin

然后在config/index.js里面开启

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-s1Hh4VR6-1655281875650)(E:\ljy\资料\img\image-20220518143854235.png)]

然后在webpack.prod.conf.js,找到这段代码

在这里插入图片描述

最后就是后端配置的问题

浏览器查看请求头,有下面这些标志就是开启成功了

在这里插入图片描述

三、路由懒加载,这种最简单的了就不多说了

const production = () => import('@/components/view/production/production')

{
    name: '123123',
    path: 'production',
    component: production
  },

四、打包不生成map文件

config/index.js

productionSourceMap: false,

五、router上面使用props传参数,导致页面加载时间很长

我在优化一个项目的时候,里面有一个单点登陆的功能页面。这个需要通过路由传参数,但是在首次进入页面的时候,浏览器捉包发现第一次请求的时候,打包的css一直被挂载长达将近20秒。

从发现这个问题开始,我一直以为是因为css文件太多,但是也就四百多kb,但是也对css文件进行各种的优化,拆分、减少背景图片的引入等等,甚至使用了CDN引入了某些css文件,减少到两百多kb最后还是一样的问题,就觉得不是这个问题。

最后我们测试,正常打开登陆页面然后进入页面,是正常的不会挂载。但是使用单点登陆就会挂载,然后就去一个测试检测,最后发现,只要把传参模式修改了,就正常了!!!!!!!!!!!!!!!!!!!!!!!!!!!

优化前的传参,使用了props

{
      name: 'Login',
      path: '/Login',
      component: Login,
      props: (route) => ({username: route.query.username})
},

优化后的参数,直接拼在路径后面

{
      name: 'Login',
      path: '/Login/:username',
      component: Login,
      // props: (route) => ({username: route.query.username})
},

我是真的栓q!

在这里插入图片描述

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

记一次vue项目优化的实例操作 的相关文章

随机推荐

  • STL——list详解

    一 list基本使用 1 1 初始化 在C 11之前 std list容器没有提供初始化列表的构造函数 因此需要使用push back或push front函数向列表中添加元素 以下是一些常见的std list初始化方式 使用默认构造函数创
  • javascript对任意颜色获取更亮或更暗的颜色值

    预处理CSS 比如Sass和less可以通过设定一个特定值 让任何颜色变得更亮或者更暗 但是在javascript中却没有这种方法 下面这个方法能在javascript中得到一个更亮或者更暗的值 通过一个给定的十六进制颜色值 比如 F06D
  • 【数据分析】基于RFM模型的线上零售中的客户细分(二):RFM模型实战

    基于RFM模型的线上零售中的客户细分 二 摘要 在上一篇博客 基于RFM模型的线上零售中的客户细分 一 客户细分 中 我们了解了什么是客户细分 这篇博客将会结合具体的商业实例介绍同期群分析 RFM模型 并利用K Means聚类算法在RFM模
  • 【已解决】XAMPP无法启动mysql

    最近在学习安卓开发 为了免于自己搭服务器 选择连接到XAMPP的mysql数据库 在这贴出自己遇到的一些问题 It seems that the port 3306 is already in use aer you sure you wa
  • ubuntu系统安装Anaconda与使用入门

    一 什么是Anaconda Anaconda是一个开源的Python发行版本 包含了conda Python等180多个科学包及其依赖项 可以用于包管理器和环境管理 比如A项目中用了Python2 而B项目使用Python3 而同时安装两个
  • Pygame实战:Python开挂版无敌小恐龙【源码免费领】

    导语 hi 大家好呀 你们还记得 很久很久以前 那只谷歌断网之后的
  • 通俗解释卡尔曼滤波

    汽车位置p和速度v例子 有点矩阵 https blog csdn net codesamer article details 81191487 飞机速度和位置 跟上面差不多 但是无矩阵 https blog csdn net varysha
  • nexus 搭建maven私服

    环境是 nexus 2 7 0 maven 3 1 1 jdk 1 7 45 CentOs 6 2 一 首先从首先从 http nexus sonatype rog downloads 下载最新版的Nexus 目前最新的版本是 nexus
  • Docker学习(23)——Docker 三剑客之 Docker Swarm集群(图形化界面管理swarm集群、添加服务等等,更方便)

    搭建过程如下 这个是基于上一片篇文章写的 1 在server1上面清空之前的所有的web服务和监控服务 我们接下来使用更加牛逼的图形化管理界面 比命令 文件的部署方式简单多了 2 可以看到server2 server3 server4上面的
  • Android减小Apk包大小的常用方法

    我们之所以要减小apk的大小 一方面是为了节省用户手机的内存 另一方面是为了节省用户在App安装和版本升级时的流量 直接减小apk文件大小的方法 1 使用图片压缩工具 目前常用的工具是 ImageOptim 压缩效果很好 使用默认配置即可
  • js 时分秒 转换为 秒

    p p
  • HTML+CSS小实战案例

    HTML CSS小实战案例 登录界面的美化 综合最近所学进行练习 网页设计先布局 搭建好大框架 然后进行填充 完成页面布局 1 2 3 4 5
  • GitHub Star超3.3K的超实用AI工具,涵盖OCR、目标检测、NLP、语音合成多个方向

    点击左上方蓝字关注我们 今天为大家推荐一个相当牛的项目 本周暴涨1300 Star 厚着脸皮大胆预判 这个项目肯定能更火 未来Star数应该可以到10k甚至20k 着急的 可以Github直接去看源码 传送门 https github co
  • 互联网上年入10万的新玩法?

    这句话说的有道理 不要用战术上的勤奋掩盖战略上的懒惰 战略是一个宏大的全局框架 总体构思 战术是微观层面的具体细节 执行步骤 做好每日复盘才能及时调整方向 完善正确的战略决策 不要闭门造车 多结交有价值的人脉圈子 经年累月耳濡目染就会变得和
  • OpenSea上如何创建自己的NFT(Polygon)

    发现 收藏和销售非凡的艺术品NFT OpenSea 是世界上第一个也是最大的 NFT 市场 一起来了解下如何通过Polygon网络 创建自己喜爱的NFT艺术品并进行收藏和交易 Polygon网络解决了ETH网络高昂的GAS费用和拥堵问题 使
  • 小程序canvas绘制邀请码

    针对小程序邀请好友功能 可以下载当前的海报图 分享给好友 好友通过扫描二维码跳转至小程序 但是邀请好友 要根据当前登录者的信息去生成二维码 目的是把邀请到的好友绑定到该用户下 所以会将二维码嵌入背景海报中 合成一张图后 生成一个临时地址 再
  • 【第十四届蓝桥杯三月真题刷题训练——第 28 天 (3.31)& 路标设置 & ​通往奥格瑞玛的道路​ & 求和 & 大师】

    第 1 题 路标设置 import java util Scanner public class Main static int N int 1e5 10 static long a new long N static int n k L
  • c++primer plus第三章复习题和编程练习

    复习题 C 为什么有多种整型 根据程序的需要选择最合适的大小 没有提供措施 程序员使用头文件limitis自己确定 33l的类型是long整型 33是默认的int整型字面量 不等价 第一条通过某种码表映射整型赋值 第二条直接赋码值 把88储
  • 【使用pandas进行数据分析】数据重构——合并与聚合、运算

    在数据清洗之后 我们可以将不同表中的数据进行合并 再进行分析 那么 数据表如何进行合并 首先 我们可以利用concat语句 import numpy as np import pandas as pd df pd read csv trai
  • 记一次vue项目优化的实例操作

    记一次vue项目优化的实例 项目前端优化是我们经常需要去做的事情 今天我们就来记录下我的实际操作 一 CDN引入 这是一个常态化的操作了 主要是让我们通过npm下载依赖包和import引入的文件 变成线上使用 减少打包后的文件大小 比如常用