热门搜索 :
宠物故事
您的当前位置:首页正文

vue-cli项目优化方法-缩短首屏加载时间

2023-11-30 来源:微宠网

这篇文章主要介绍了vue-cli项目优化 缩短首屏加载时间,需要的朋友可以参考下

最近实习的项目需求上要求不多,就学了下项目优化,主要是首屏加载太慢。

大文件定位

我们可以使用webpack可视化插件Webpack Bundle Analyzer 查看工程js文件大小,然后有目的的解决过大的js文件。

安装

在webpack中设置如下,然后npm run dev 的时候默认会在8888端口显示。

JS文件按需加载

如果没有这个设置,项目首屏加载时会加载整个网站所有的JS文件,所以将JS文件拆开,点击某个页面时再加载该页面的JS是一个很好的优化方法。

这里用到的就是vue的组件懒加载。在router.js中,不要使用import的方法引入组件,使用require.ensure。

使用cdn

打包时,把vue、vuex、vue-router、axios等,换用国内的bootcdn 直接引入到根目录的index.html中。

在webpack设置中添加externals,忽略不需要打包的库。

在index.html中使用cdn引入。

将JS文件放在body的最后

默认情况下,build后的index.html中,js的引入是在header中。

使用html-webpack-plugin插件,将inject的值改成body。就可以将js引入放到body最后。

压缩代码并移除console

使用UglifyJsPlugin 插件来压缩代码和移除console。

上面是我整理给大家的,希望今后会对大家有帮助。

相关文章:

微信小程序block的使用教程

详解PHP后期静态绑定分析与应用

微信小程序wx:for和wx:for-item的用法详解

小编还为您整理了以下内容,可能对您也有帮助:

vue-cli项目中如何缩短首屏加载时间以提高效率

本篇文章所说的内容是vue-cli项目中如何缩短首屏加载时间以提高效率,代码都非常详细,有需要的朋友可以看一下。

主要是首屏加载太慢。

大文件定位

我们可以使用webpack可视化插件Webpack Bundle Analyzer 查看工程js文件大小,然后有目的的解决过大的js文件。

安装

npm install --save-dev webpack-bundle-analyzer

在webpack中设置如下,然后npm run dev 的时候默认会在8888端口显示。

const BundleAnalyzerPlugin = require('webpack-bundle-analyzer').BundleAnalyzerPlugin;

mole.exports = {

plugins: [

new BundleAnalyzerPlugin()

]

}JS文件按需加载

如果没有这个设置,项目首屏加载时会加载整个网站所有的JS文件,所以将JS文件拆开,点击某个页面时再加载该页面的JS是一个很好的优化方法。

这里用到的就是vue的组件懒加载。在router.js中,不要使用import的方法引入组件,使用require.ensure。

import index from '@/components/index'

const index = r => require.ensure( [], () => r (require('@/components/index'),'index'))

//如果写了第二个参数,就打包到该`/JS/index` 的文件中。

//不写第二个参数,就直接打包在`/JS` 目录下。

const index = r => require.ensure( [], () => r (require('@/components/index')))使用cdn

打包时,把vue、vuex、vue-router、axios等,换用国内的bootcdn 直接引入到根目录的index.html中。

在webpack设置中添加externals,忽略不需要打包的库。

externals: {

'vue': 'Vue',

'vue-router': 'VueRouter',

'vuex': 'Vuex',

'axios': 'axios'

}在index.html中使用cdn引入。

<script src="//cdn.bootcss.com/vue/2.2.5/vue.min.js"></script>

<script src="//cdn.bootcss.com/vue-router/2.3.0/vue-router.min.js"></script>

<script src="//cdn.bootcss.com/vuex/2.2.1/vuex.min.js"></script>

<script src="//cdn.bootcss.com/axios/0.15.3/axios.min.js"></script>将JS文件放在body的最后

默认情况下,build后的index.html中,js的引入是在header中。

使用html-webpack-plugin插件,将inject的值改成body。就可以将js引入放到body最后。

var HtmlWebpackPlugin = require('html-webpack-plugin');

new HtmlWebpackPlugin({

inject: 'body',})

压缩代码并移除console

使用UglifyJsPlugin 插件来压缩代码和移除console。

new webpack.optimize.UglifyJsPlugin({

compress: {

warnings: false,

drop_console: true,

pure_funcs: ['console.log']

},

sourceMap: false

})

vue中如何优化单页应用首屏加载速度(详细)

本篇文章给大家带来的内容是关于vue中如何优化单页应用首屏加载速度(详细) ,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

单页应用会随着项目越大,导致首屏加载速度很慢!!!以下给出在下知道的几种优化方案

使用CDN资源,减小服务器带宽压力

路由懒加载

将一些静态js css放到其他地方(如OSS),减小服务器压力

按需加载三方资源,如iview,建议按需引入iview中的组件

使用nginx开启gzip减小网络传输的流量大小

webpack开启gzip压缩

若首屏为登录页,可以做成多入口,登录页单独分离为一个入口

使用CDN资源,减小服务器带宽压力在index.html中引入cdn资源

...

<body>

<p id="app">

</p>

<!-- built files will be auto injected -->

<script src="https://cdn.bootcss.com/vue/2.5.2/vue.min.js"></script>

<script src="https://cdn.bootcss.com/vue-router/3.0.1/vue-router.min.js"></script>

<script src="https://cdn.bootcss.com/vuex/3.0.1/vuex.min.js"></script>

<script src="https://cdn.bootcss.com/vue-resource/1.5.1/vue-resource.min.js"></script>

</body>

...修改 build/webpack.base.conf.js

mole.exports = {

context: path.resolve(__dirname, '../'),

entry: {

app: './src/main.js'

},

externals:{

'vue': 'Vue',

'vue-router': 'VueRouter',

'vuex':'Vuex',

'vue-resource': 'VueResource'

},

...

}修改src/main.js src/router/index.js 注释掉import引入的vue,vue-resource

// import Vue from 'vue'

// import VueResource from 'vue-resource'

// Vue.use(VueResource)路由懒加载const workCircle = r => require.ensure([], () => r(require('@/mole/work-circle/Index')), 'workCircle')

const workCircleList = r => require.ensure([], () => r(require('@/mole/work-circle/page/List')), 'workCircleList')将一些静态js css放到其他地方(如OSS),减小服务器压力注意这里的js文件,需要将结果抛出,然后在需要用到该js的组件中import引入

按需加载三方资源,如iview,建议按需引入iview中的组件按需引用请查看iview官方文档iview

使用nginx开启gzip减小网络传输的流量大小配置nginx,可以参考Nginx开启Gzip压缩大幅提高页面加载速度

webpack开启gzip压缩这里需要配合Nginx服务器,Nginx开启gzip

config/index.js中

mole.exports = {

build: {

...

// Gzip off by default as many popular static hosts such as

// Surge or Netlify already gzip all static assets for you.

// Before setting to `true`, make sure to:

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

proctionGzip: true, // 就是这里开启gzip,vue-cli搭建项目,这里默认为false

proctionGzipExtensions: ['js', 'css'],

// Run the build command with an extra argument to

// View the bundle analyzer report after build finishes:

// `npm run build --report`

// Set to `true` or `false` to always turn it on or off

bundleAnalyzerReport: process.env.npm_config_report

}

}build/webpack.prod.conf.js中

使用vue-cli构建项目时,默认会有这段代码

if (config.build.proctionGzip) {

const CompressionWebpackPlugin = require('compression-webpack-plugin')

webpackConfig.plugins.push(

new CompressionWebpackPlugin({

asset: '[path].gz[query]',

algorithm: 'gzip',

test: new RegExp(

'.(' +

config.build.proctionGzipExtensions.join('|') +

')$'

),

threshold: 10240,

minRatio: 0.8

})

)

}若首屏为登录页,可以做成多入口,登录页单独分离为一个入口

Vue怎么使用CDN优化首屏加载的速度

这次给大家带来Vue怎么使用CDN优化首屏加载的速度,Vue使用CDN优化首屏加载速度的注意事项有哪些,下面就是实战案例,一起来看一下。

前言

作为一个网站应用,加载速度是非常重要的。加载速度,一个是程序的合理安排,如以组件按需加载,一个是js、css等资源的异步加载。

在Vue项目中,引入到工程中的所有js、css文件,编译时都会被打包进vendor.js,浏览器在加载该文件之后才能开始显示首屏。若是引入的库众多,那么vendor.js文件体积将会相当的大,影响首开的体验。

解决方法是,将引用的外部js、css文件剥离开来,不编译到vendor.js中,而是用资源的形式引用,这样浏览器可以使用多个线程异步将vendor.js、外部的js等加载下来,达到加速首开的目的。

外部的库文件,可以使用CDN资源,或者别的服务器资源等。

下面,以引入vue、vuex、vue-router为例,说明处理流程。

一、资源引入

在index.html中,添加CDN资源,例如bootstrap:

<body>

<p id="app"></p>

<script src="https://cdn.bootcss.com/vue/2.5.2/vue.min.js"></script>

<script src="https://cdn.bootcss.com/vue-router/3.0.1/vue-router.min.js"></script>

<script src="https://cdn.bootcss.com/vuex/3.0.1/vuex.min.js"></script>

</body>二、添加配置

在bulid/webpack.base.conf.js文件中,增加externals,将引用的外部模块导入,如下:

mole.exports = {

entry: {

app: './src/main.js'

},

externals:{

'vue': 'Vue',

'vue-router': 'VueRouter',

'vuex':'Vuex'

}注意一点:

格式为 'aaa' : 'bbb', 其中,aaa表示要引入的资源的名字,bbb表示该模块提供给外部引用的名字,由对应的库自定。例如,vue为Vue,vue-router为VueRouter.

三、去掉原有的引用

去掉import,如:

// import Vue from 'vue'

// import Router from 'vue-router'去掉Vue.use(XXX),如:

// Vue.use(Router)

相信看了本文案例你已经掌握了方法,更多精彩请关注Gxl网其它相关文章!

推荐阅读:

JSON格式的数据如何提交到服务端

新手入门如何学习vue

JS动态加载时重复绑定如何处理

怎样处理vue-router懒加载时候第一次加载资源过多导致速度缓慢

这次给大家带来怎样处理vue-router懒加载时候第一次加载资源过多导致速度缓慢,处理vue-router懒加载时候第一次加载资源过多导致速度缓慢的注意事项有哪些,下面就是实战案例,一起来看一下。

像vue这种单页面应用,如果没有应用懒加载,运用webpack打包后的文件将会异常的大,造成进入首页时,需要加载的内容过多,时间过长,会出啊先长时间的白屏,即使做了loading也是不利于用户体验,而运用懒加载则可以将页面进行划分,需要的时候加载页面,可以有效的分担首页所承担的加载压力,减少首页加载用时。

简单的说就是:进入首页不用一次加载过多资源造成用时过长!!!

懒加载的方式:

import Vue from 'vue'

import Router from 'vue-router'

Vue.use(Router)

//采用了懒加载

export default new Router({

routes: [

{

path:'/',

component:resolve => require(['@/components/index'],resolve)

}

]

})非懒加载的方式:

import Vue from 'vue'

import Router from 'vue-router'

import index from '@/components/index'

Vue.use(Router)

export default new Router({

routes: [

{

path:'/',

component:index

}

]

})ps:下面看下vue-router路由懒加载

用vue.js写单页面应用时,会出现打包后的JavaScript包非常大,影响页面加载,我们可以利用路由的懒加载去优化这个问题,当我们用到某个路由后,才去加载对应的组件,这样就会更加高效,实现代码如下:

import Vue from 'vue'

import Router from 'vue-router'

Vue.use(Router)

export default new Router({

routes: [

{

path: '/',

component: resolve => require(['components/Hello.vue'], resolve)

},

{

path: '/about',

component: resolve => require(['components/About.vue'], resolve)

}

]

})相信看了本文案例你已经掌握了方法,更多精彩请关注Gxl网其它相关文章!

推荐阅读:

从零开始使用React Router v4

怎样使用JS做出动态添加HTML标记

微宠网还为您提供以下相关内容希望对您有帮助:

vue项目首屏打开速度慢?我来带你飞。

那缺少的elementui文件去哪里找呢?答案是cdn引用。之前项目里还有引用moment,但是这个库实在是太大了,在github上我找到一个跟momentapi完全一样的库,但是文件大小只要2kb。其他优化方法还有ssr,这个最好用nuxtjs来做,自...

vue中如何优化单页应用首屏加载速度(详细)

建议按需引入iview中的组件使用nginx开启gzip减小网络传输的流量大小webpack开启gzip压缩若首屏为登录页,可以做成多入口,登录页单独分离为一个入口使用CDN资源,减小服务器带宽压力在index.html中引入cdn资源... &lt;!-- bui...

Vue怎样使用CDN优化首屏加载

一、资源引入在index.html中,添加CDN资源,例如bootstrap:

Vue项目优化

vue.config.js 默认情况下,import导入的第三方依赖会被打包进同一个文件,造成文件体积过大进而影响加载速度。通过配置 externals 结点将需要全局导入的第三方依赖排除在打包文件外,可以有效减少打包体积 声明方式为 依赖包名:...

VueCLI3打包优化--抽离依赖包

减少打包体积、加快打包速度,常规的优化有以下两种:按需加载是通过只引用使用的组件来减少体积,这就会有一个问题:如果项目重度依赖第三方插件(如 ElementUI 、 vant ),那么此方案将无法减少打包的体积。这里选择CDN的方...

怎么提速优化vue-cli的代码

然后通过引入第三方组件框架和工具的方式进行开发构建,我个人也十分推崇这种做法。但是vue-cli初始化的项目模板毕竟是面向所有开发者的,在兼容性方面会有一定妥协。相信很多人都已经搜索过各类的webpack构建优化文章,但是很多不...

如何优化Vue

所以建议只在生成环境之中使用路由懒加载功能。6.2 优化根据Vue的异步组件和Webpack的代码分割功能可以轻松实现组件的懒加载,如:const Foo = () =&gt; import('./Foo.vue')在区分开发环境与生产环境时,可以在路由文件夹下分别新建两个...

详解如何在webpack中做预渲染降低首屏空白时间

渲染内容下面我们主要是讨论一下如何通过预渲染的方式降低空白屏的时间缩小首屏载时间是一个重要的优化项,总结来主要有以下几种方式: 1、尽可能的缩小webpack或者其他打包工具生成的包的大小 2、使用服务端渲染的方式 3、...

在vue中如何使用cdn优化

在我们写项目中,优化问题是不容忽视的,尤其是首屏优化更是重中之重,这里介绍两种方法优化方法—-cdn和异步加载,异步请看 //www.gxlcms.com/article/110661.htm1。cdn 首先cdn是什么,自己百度哦其作用是:当我们加载...

vue中v-cloak在刷新与加载时闪烁如何处理

和 CSS 规则如 [v-cloak] { display: none } 一起用时,这个指令可以隐藏未编译的 Mustache 标签直到实例准备完毕。官方API {{msg}}HTML 绑定 Vue实例,在页面加载时会闪烁然后才会出现 加载完成 字样,为了效果更明显...

Top