一.项目优化策略

1.生成打包报告

2.第三方库启用CDN

3.Element-ui组件按需加载

4.首页内容定制

5.路由懒加载

1.生成打包报告

1.1通过vue-cli的UI面板直接查看
1.2通过命令行参数生成报告
// 生成report.html分析报告
vue-cli-service build --report

2.修改webpack配置

https://cli.vuejs.org/zh/config/#vue-config-js

如果有修改webpack默认配置的需求,可以在项目根目录创建vue.config.js配置文件

2.1为开发模式与发布模式指定不同的打包入口
module.exports = {
chainWebpack: config => {
// 指定发布模式打包入口
config.when(process.env.NODE_ENV === 'production', config => {
config
.entry('app')
.clear()
.add('./src/main-prod.js')
}) // 指定开发模式打包入口
config.when(process.env.NODE_ENV === 'development', config => {
config
.entry('app')
.clear()
.add('./src/main-dev.js')
})
}
}
2.2通过externals加载外部CDN资源

默认情况下,通过import导入的第三方依赖包最终会被打包合并到一个文件中,导致打包后单文件体积过大。所以我们需要通过webpack的externals节点,配置加载外部CDN资源,凡是声明在externals中的第三方依赖包都不会被打包。

  1. 配置vue.config.js文件

    module.exports = {
    chainWebpack: config => {
    // 指定发布模式打包入口
    config.when(process.env.NODE_ENV === 'production', config => {
    config
    .entry('app')
    .clear()
    .add('./src/main-prod.js') // 使用externals加载外部CDN资源
    config.set('externals', {
    vue: 'Vue',
    'vue-router': 'VueRouter',
    axios: 'axios',
    lodash: '_',
    echarts: 'echarts',
    nprogress: 'NProgress',
    'vue-quill-editor': 'VueQuillEditor'
    })
    }) // 指定开发模式打包入口
    config.when(process.env.NODE_ENV === 'development', config => {
    config
    .entry('app')
    .clear()
    .add('./src/main-dev.js')
    })
    }
    }
  2. 在public/index.html文件头部,添加第三方依赖包的js和css样式的CDN引用

    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-MNWKI4Ry-1604394495531)(https://s1.ax1x.com/2020/11/03/Bsfrcj.png)]

3.通过CDN加载element-ui的组件

  1. 在main-prod.js中,注释掉element-ui按需加载的代码

    // import './plugins/element.js'
  2. 在index.html头部,通过CDN加载element-ui的js和css

4.首页内容定制(看需求决定用不用)

不同打包环境下,首页内容页可能不同,可以通过插件进行配置

  1. 配置vue.config.js文件

    module.exports = {
    chainWebpack: config => {
    // 指定发布模式打包入口
    config.when(process.env.NODE_ENV === 'production', config => {
    config
    .entry('app')
    .clear()
    .add('./src/main-prod.js') // 使用externals加载外部CDN资源
    config.set('externals', {
    vue: 'Vue',
    'vue-router': 'VueRouter',
    axios: 'axios',
    lodash: '_',
    echarts: 'echarts',
    nprogress: 'NProgress',
    'vue-quill-editor': 'VueQuillEditor'
    }) config.plugin('html').tap(args => {
    args[0].isProd = true
    return args
    })
    }) // 指定开发模式打包入口
    config.when(process.env.NODE_ENV === 'development', config => {
    config
    .entry('app')
    .clear()
    .add('./src/main-dev.js') config.plugin('html').tap(args => {
    args[0].isProd = false
    return args
    })
    })
    }
    }
  2. 在public/index.html中,根据isProd的值,决定如何渲染页面结构

    <!- 按需渲染页面标题 -->
    <title><%= htmlWebpackPlugin.options.isProd ? '' : 'dev - ' %>标题</title> <!- 按需加载外部CDN -->
    <% if(htmlWebpackPlugin.options.isProd){ %>
    <!- 通过externals加载的外部CDN资源 -->
    <% } %>

5.路由懒加载

当打包构建项目时,JavaScriot包会变得非常大,影响页面加载。所以我们将不同路由对应的组件分割成不同的代码块,当路由被访问时才加载对应组件。

  1. 安装插件包

    开发依赖 @babel/plugin-syntax-dynamic-import
  2. 在babel.config.js中的plugins声明该插件

    '@babel/plugin-syntax-dynamic-import'
  3. 将路由改为按需加载的形式

    const Foo = () => import(/* webpackChunkName: "grounp-foo" */ './Foo.vue')
    const Bar = () => import(/* webpackChunkName: "grounp-foo" */ './Bar.vue')
    const Baz = () => import(/* webpackChunkName: "grounp-boo" */ './Baz.vue')

二.项目上线配置

1.通过node创建web服务器

2.开启gzip配置

3.配置https服务

4.使用pm2管理应用

1.通过node创建web服务器

创建node项目,并安装express,通过express快速创建web服务器,将vue打包生成的dist文件夹托管为静态资源即可。

npm init -y
npm i express -S
// 新建app.js
const express = require('express')
const app = express() app.use(express.static('./dist')) app.listen(80, () => {
console.log('server running at http://127.0.0.1')
})

2.开启gzip配置

使用gzip可以减小文件体积,传输速度更快。

npm install compression -D
const compression = require('compression')
app.use(compression())
const express = require('express')
const compression = require('compression')
const app = express() // 一定要把这一行代码,写到 静态资源托管之前
app.use(compression())
app.use(express.static('./dist')) app.listen(80, () => {
console.log('server running at http://127.0.0.1')
})

3.配置HTTPS服务(一般后端去做,了解即可)

传统的http都是明文,不安全,所以使用https进行加密处理,防止数据窃取

1. 申请SSL证书
2. 证书导入
const https = require('https')
const fs = require('fs')
const options = {
cert: fs.readFileSync('./full_chain.pem'),
key: fs.readFileSync('./private.key')
}
https.createServer(options, app).listen(443)
const express = require('express')
const compression = require('compression')
const https = require('https')
const fs = require('fs')
const app = express() const options = {
cert: fs.readFileSync('./full_chain.pem'),
key: fs.readFileSync('./private.key')
} // 一定要把这一行代码,写到 静态资源托管之前
app.use(compression())
app.use(express.static('./dist')) // http服务
// app.listen(80, () => {
// console.log('server running at http://127.0.0.1')
// }) // https服务
https.createServer(options, app).listen(443)

4.使用pm2管理应用

终端窗口使用node开启服务后,不能关闭。所以使用pm2管理应用,解放终端窗口。

pm2使用:

启动项目:pm2 start脚本 --name自定义名称

查看运行项目:pm2 ls

重启项目:pm2 restart 自定义名称

停止项目:pm2 stop 自定义名称

删除项目:pm2 delete 自定义名称

npm i pm2 -g
pm2 start .\app.js --name demo_vue

vue项目优化与上线的更多相关文章

  1. Vue项目优化首屏加载速度

    Vue项目部署上线后经常会发现首屏加载的速度特别慢:那么有那写能做的简单优化呢 一.路由的懒加载 路由懒加载也就是 把不同路由对应的组件分割成不同的代码块,然后当路由被访问的时候才加载对应组件. 结合 ...

  2. vue项目 打包部署上线

    1. npm run dev:本地开发的时候做调试用的. 2. npm run build:打包部署上线,生成一个 dist 文件夹. 注意:用 npm run build 时,常遇到因引用路径不对导 ...

  3. 用prerender-spa-plugin插件Vue项目优化SEO做ssr服务端渲染及预渲染

    今天在做公交的时候没干,用手机看看文章,偶然发现了一个关于Vue优化seo的文章,我先是在Vue的官方文档看了一篇关于Vue做SEO优化的文章. 上面提到了nuxt.js这个框架,这个框架我做过一个小 ...

  4. vue项目优化--使用CDN和Gzip

    使用vue-cli构建的vue项目,在打包发布的时候,发现打包后的文件体积很大,使用webpack-bundle-analyzer分析后,发现占用空间最多的是引用的第三方依赖.第三方的依赖文件可以使用 ...

  5. vue项目优化之按需加载组件-使用webpack require.ensure

    require-ensure和require-amd的区别: require-amd 说明: 同AMD规范的require函数,使用时传递一个模块数组和回调函数,模块都被下载下来且都被执行后才执行回调 ...

  6. Vue 项目优化,持续更新...

    一.减少打包的体积 通过vue-cli 初始化项目后,使用 npm run build 生成的JS文件往往会很大,加载时间过长导致页面长时间白屏,所以我们尽可能的使用一下方法来减少打包体积. 1.1 ...

  7. 第十章、Vue项目的联调上线

    抓包 Fiddler 一.解决跨域 proxyTable(查看博客总结) 二.解决用本机ip地址不能访问 在dev中加上 --host 0.0.0.0就可以用本机ip访问,这样的话可以用手机在内网(局 ...

  8. vue项目优化,加快服务器端渲染速度

    1. CSS在开发模式中用import,在打包后用CDN min.js中做如下操作 if (process.env.NODE_ENV == 'development') { require('../x ...

  9. vue项目优化之路由懒加载

    const login = () =>import('@/views/login'); export default new Router({ routes:[ { path:'/login', ...

随机推荐

  1. 单元测试框架怎么搭?快来看看新版Junit5的这些神奇之处吧!

    为什么使用JUnit5 JUnit4被广泛使用,但是许多场景下使用起来语法较为繁琐,JUnit5中支持lambda表达式,语法简单且代码不冗余. JUnit5易扩展,包容性强,可以接入其他的测试引擎. ...

  2. SpringMVC参数返回给页面

    springMVC将后台参数返回给前台页面 方法一:利用ModelAndView返回值 1 @RequestMapping("/returnPage.do") 2 public M ...

  3. Python-字符串解析-正则-re

    正则表达式 特殊字符序列,匹配检索和替换文本 普通字符 + 特殊字符 + 数量,普通字符用来定边界 更改字符思路 字符串函数 > 正则 > for循环 元字符 匹配一个字符 # 元字符大写 ...

  4. Hbuilder MUI 下拉选择与时间选择器

    一. Hbuilder 下拉选择 <link rel="stylesheet" href="../../../assets/mui/css/mui.picker.m ...

  5. 009 01 Android 零基础入门 01 Java基础语法 02 Java常量与变量 03 什么是变量?

    009 01 Android 零基础入门 01 Java基础语法 02 Java常量与变量 03 什么是变量? 什么是变量? 形象化的生活中的例子理解什么是变量以及变量的三个元素 我们可以根据客人要求 ...

  6. JavaScript reduce()的使用

    语法 arr.reduce(callback(accumulator, currentValue, index, array), initialValue) 参数 callback 执行数组中每个值 ...

  7. 用集装箱装ASP。带有Docker和Azure Kubernetes服务的NET Core应用程序

    介绍 曾经有一个单一软件应用程序的时代,整个应用程序被打包并部署在作为单个进程运行的单个服务器上.我们都知道,在这个模型中,单点故障可能会导致整个应用程序崩溃. 微服务体系结构的发展是为了解决单片应用 ...

  8. 15.深入k8s:Event事件处理及其源码分析

    转载请声明出处哦~,本篇文章发布于luozhiyun的博客:https://www.luozhiyun.com 源码版本是1.19 概述 k8s的Event事件是一种资源对象,用于展示集群内发生的情况 ...

  9. LVS搭建

    LVS集群搭建 NAT架构图 1.在RS188,RS189操作 #安装httpd服务[root@t1 ~]# yum install -y httpd[root@t1 ~]# echo "I ...

  10. UVA 10635 Prince and Princess—— 求LCS(最长公共子序列)转换成 求LIS(最长递增子序列)

    题目大意:有n*n个方格,王子有一条走法,依次经过m个格子,公主有一种走法,依次经过n个格子(不会重复走),问他们删去一些步数后,重叠步数的最大值. 显然是一个LCS,我一看到就高高兴兴的打了个板子上 ...