当前位置:首页 > 技术分析 > 正文内容

只需要3招将你的Vue项目访问时间从1分钟缩短到3秒以内

ruisui884周前 (03-31)技术分析7

前言:

基于Vuecli搭建的vue项目简单快捷,易于开发。在node.js的加持下你可以更快的引入万千JavaScript开发库,仅仅依靠前端就可以实现以前使用后端才能实现的功能,如通过axios便可以快捷的与后端进行数据交互等。

但是vuecli搭建的项目也处在一些不足,在安照vue官方进行开发时往往存在引入JavaScript库较多,导致项目过大访问时花费的时间较长,特别在服务器带宽较低时就会存在访问时间较长,乃至30s甚至1分钟以上也是存在的。例如euiadmin的服务器带宽是1mbps的在没有优化前,用Chrome浏览器访问时间常常为35s以上,经过优化现在访问时间控制在3s左右。

前期准备:

在项目根目录下创建vue.config.js,这是前期必须要准备的,如果不理解可以前往euiadmin.com官网下载源码进行查看。

优化方法:

1、路由懒加载

在router/index.js中采用如下书写形式,采用resolve进行加载。


{

path: '/module/animate',

name: 'animate',

component: resolve => require(['@/views/module/Animate.vue'], resolve),

meta: {

title: 'Eui动画',

login_state: true,

vist_label: ['super_admin', 'admin']

},

},

2、子组件懒加载

示例JavaScript代码:

<script>

export default {

components: {

HomeSpace:resolve=>{require(['@/components/home/HomeSpace'],resolve)},

},

};

</script>

注意:

使用子组件懒加载在进入首页时会较快,但是进入相应的子组件时特别是富文本等使用JavaScript库的子组件时加载时间可能较长,如果您不在乎首页加载时间可以不使用懒加载。

3、CDN引用加载,减少打包体积加快访问速度

(1)在public/index.html中引用需要引用的内容(以EuiAdmin作为参考)。

<script src="https://cdn.jsdelivr.net/npm/vue"></script>

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

<script src="https://unpkg.com/element-ui/lib/index.js"></script>

<script src="https://unpkg.com/vue-cookies@1.7.4/vue-cookies.js"></script>

<script src="https://cdn.bootcss.com/echarts/4.2.1-rc1/echarts.js"></script>

<%= htmlwebpackplugin.options.title>

(2)在项目根目录vue.config.js中写下如下内容。

(1)移除 prefetch 插件,不移除会在访问时加载所有项目内容。

参考代码:

chainWebpack: config => {

config.plugins.delete('prefetch')

},

(2)去除指定的JavaScript库不打包。

configureWebpack: { //移除已从cdn引入的组件,不打包以下命名的内容

externals: {

'vue': 'Vue',

'vue-router': 'VueRouter',

'element-ui': 'ELEMENT',

'echarts': 'echarts',

'VueCookies': 'VueCookies',

},

},

完整的vue.config.js内容

// Vue.config.js 配置选项

module.exports = {

publicPath: "./",

// 构建时的输出目录

outputDir: "dist",

// 放置静态资源的目录

assetsDir: "static",

transpileDependencies: [ /* string or regex */ ],

// 是否为生产环境构建生成 source map?

productionSourceMap: false,

devServer: {

open: true,

host: 'localhost',

port: 8080,

https: false,

//以上的ip和端口是我们本机的;下面为需要跨域的

proxy: { //配置跨域

'/api': {

target: 'http://localhost', //这里后台的地址模拟的;应该填写你们真实的后台接口

ws: true,

changOrigin: true, //允许跨域

pathRewrite: {

'^/api': '' //请求的时候使用这个api就可以

}

}

}


},

configureWebpack: { //移除已从cdn引入的组件,不打包以下命名的内容

externals: {

'vue': 'Vue',

'vue-router': 'VueRouter',

'element-ui': 'ELEMENT',

'echarts': 'echarts',

'VueCookies': 'VueCookies',

},

},

chainWebpack: config => {

// 移除 prefetch 插件

config.plugins.delete('prefetch')

},


}

注意事项:

1、 在使用子组件懒加载时需要在整个项目中都要使用,不然会导致加载时间过长。

2、 Cdn加载时一定要配合vue.config.js二者相互使用否则不生效。

结语:

具体的代码你可以前往euiadmin.com下载源码进行参考,如果你要运行euiamdin项目那么你需要在自己电脑搭建运行环境(node.js+vuecli)。

如果您喜欢可以"关注、评论和收藏"哦。

扫描二维码推送至手机访问。

版权声明:本文由ruisui88发布,如需转载请注明出处。

本文链接:http://www.ruisui88.com/post/3187.html

分享给朋友:

“只需要3招将你的Vue项目访问时间从1分钟缩短到3秒以内” 的相关文章

宽带客户收费管理系统--维修版

宽带客户收费管理系统--维修版headerfooter《宽带客户收费管理系统——维修版》是一款适合宽带运营商使用的管理系统。软件主要包括以下功能:1.主要功能包括用户开户、收费录入、工单登记、故障处理;2.自定义套餐及收费功能;3.强大的查询功能和数据备份功能以及严密的用户权限功能;4.界面设计简洁...

祸害阿里云宕机3小时的IO HANG究竟是什么?

本文来自微信公号“CSDN”(ID:CSDNnews),作者 | 王知无, 责编| 郭 芮。2019年3月3日凌晨,微博炸锅,有网友反映说阿里云疑似出现宕机,华北很多互联网公司受到暴击伤害,APP、网站全部瘫痪,我自己的朋友圈和微信群里也有好友反馈,刚刚从被窝被叫起来去修Bug,结果发现服务器登不上...

面试被逼疯:聊聊Python Import System?

面试官一个小时逼疯面试者:聊聊Python Import System?对于每一位Python开发者来说,import这个关键字是再熟悉不过了,无论是我们引用官方库还是三方库,都可以通过import xxx的形式来导入。可能很多人认为这只是Python的一个最基础的常识之一,似乎没有可以扩展的点了,...

Vue实现动态路由

通常我们在vue项目中都是前端配置好路由的,但在一些项目中我们可能会遇到权限控制,这样我们就涉及到动态路由的设置了。动态路由设置一般有两种:(1)、简单的角色路由设置: 比如只涉及到管理员和普通用户的权限。通常直接在前端进行简单的角色权限设置(2)、复杂的路由权限设置: 比如OA系统、多种角色的权限...

Vue中的路由配置常用属性

router:路由页面跳转的核心库;引入路由:import VueRouter from 'vue-router'; 注册路由:const router = new VueRouter({ })mode:模式路由有hash history两种模式:hash模式URL中包含#,#后边是...

thinkphp8+vue3微信小程序商城,发布公众号App+SAAS+多商户

项目介绍三勾小程序商城基于thinkphp8+vue3+element-ui+uniapp打造的面向开发的小程序商城,方便二次开发或直接使用,可发布到多端,包括微信小程序、微信公众号、QQ小程序、支付宝小程序、字节跳动小程序、百度小程序、android端、ios端。支持主题色+自定义头部导航+自定义...