iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >vue-router实现路由懒加载的方法有哪些
  • 659
分享到

vue-router实现路由懒加载的方法有哪些

2023-06-06 14:06:41 659人浏览 独家记忆
摘要

这篇文章给大家介绍Vue-router实现路由懒加载的方法有哪些,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。什么是路由懒加载?也叫延迟加载,即在需要的时候进行加载,随用随载。官方解释: 1:当打包构建应用时

这篇文章给大家介绍Vue-router实现路由懒加载的方法有哪些,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。

什么是路由懒加载?

也叫延迟加载,即在需要的时候进行加载,随用随载。

官方解释:

 1:当打包构建应用时,javascript 包会变得非常大,影响页面加载。

 2:如果我们能把不同路由对应的组件分割成不同的代码块,然后当路由被访问的时候才加载对应组件,这样就更加高效了。

官方在说什么呢?为什么需要懒加载?

 1:首先,我们知道路由中通常会定义很多不同的页面。

 2:这个页面这项目build打包后,一般情况下,会放在一个单独的js文件中

 3:但是,如果很多的页面都放在同一个js文件中,必然会造成这个页面非常大

 4:如果我们一次性的从服务器中请求下来这个页面,可能会花费一定时间,用户体验不好

 5:如何避免这种情况发生呢?使用路由懒加载就可以了

继续解释原由?

    1:像vue这种单页面应用,如果没有应用懒加载,运用webpack打包后的文件将会异常的大。

    2:造成进入首页时,需要加载的内容过多,时间过长,会出啊先长时间的白屏,即使做了loading也是不利于用户体验。

    3:而运用懒加载则可以将页面进行划分,需要的时候加载页面,可以有效的分担首页所承担的加载压力,减少首页加载用时

也就是说:进入页面不用也不需要一次性加载过多资源造成加载时间过程!

路由懒加载做了什么事情?

 1:主要作用是将路由对应的组件打包成一个个的js代码块

 2:只有在这个路由被访问到的时候,才加载对应的组件,否则不加载!

即:只有在这个路由被访问到的时候,才加载对应的组件,否则不加载!

1:.如何实现路由懒加载??

 vue项目实现路由按需加载(路由懒加载)的三种方式:

  1:Vue异步组件

  2:es6标准语法import()---------推荐使用!!!!!

  3:WEBpack的require,ensure()

2.Vue异步加载技术

  1:vue-router配置路由,使用vue的异步组件技术,可以实现懒加载,此时一个组件会生成一个js文件。

  2:component: resolve => require(['放入需要加载的路由地址'], resolve)

 { path: '/problem', name: 'problem', component: resolve => require(['../pages/home/problemList'], resolve) }

3.ES6推荐方式imprort ()----推荐使用

  1:直接将组件引入的方式,import是ES6的一个语法标准,如果需要浏览器兼容,需要转化成es5的语法。

  2:推荐使用这种方式,但是注意wepack的版本>2.4

  3:vue官方文档中使用的也是import实现路由懒加载

  4:上面声明导入,下面直接使用

import Vue from 'vue';import Router from 'vue-router';// 官网可知:下面没有指定webpackChunkName,每个组件打包成一个js文件。const Foo = () => import('../components/Foo')const Aoo = () => import('../components/Aoo')// 下面2行代码,指定了相同的webpackChunkName,会合并打包成一个js文件。// const Foo = () => import( '../components/Foo')// const Aoo = () => import( '../components/Aoo')export default new Router({ routes: [  {   path: '/Foo',   name: 'Foo',   component: Foo  },  {   path: '/Aoo',   name: 'Aoo',   component: Aoo  } ]})

4.webpack提供的require.ensure()实现懒加载:

  1:vue-router配置路由,使用webpack的require.ensure技术,也可以实现按需加载。

  2:这种情况下,多个路由指定相同的chunkName,会合并打包成一个js文件。

  3:require.ensure可实现按需加载资源,包括js,CSS等。他会给里面require的文件单独打包,不会和主文件打包在一起。

  4:第一个参数是数组,表明第二个参数里需要依赖的模块,这些会提前加载。

 5:第二个是回调函数,在这个回调函数里面require的文件会被单独打包成一个chunk,不会和主文件打包在一起,这样就生成了两个chunk,第一次加载时只加载主文件。

 6:第三个参数是错误回调。

 7:第四个参数是单独打包的chunk的文件名

此处代码参考原文链接:https://blog.csdn.net/qq_41998083/article/details/109726402

import Vue from 'vue';import Router from 'vue-router';const HelloWorld=resolve=>{require.ensure(['@/components/HelloWorld'],()=>{resolve(require('@/components/HelloWorld'))})}Vue.use('Router')export default new Router({routes:[{{path:'./',name:'HelloWorld',component:HelloWorld}}]})

4.import和require的比较(了解)

import 是解构过程并且是编译时执行

require 是赋值过程并且是运行时才执行,也就是异步加载

require的性能相对于import稍低,因为require是在运行时才引入模块并且还赋值给某个变量

关于vue-router实现路由懒加载的方法有哪些就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

--结束END--

本文标题: vue-router实现路由懒加载的方法有哪些

本文链接: https://www.lsjlt.com/news/247525.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • c#程序自启动怎么设置
    c# 程序的自启动方法有三种:注册表:在指定注册表项下创建新值,并将其设置为程序可执行文件路径。任务计划程序:创建一个新任务,并在触发器和动作部分分别指定登录时或特定时间触发,以及启动程...
    99+
    2024-05-14
    c#
  • c#怎么调用dll文件
    可在 c# 中轻松调用 dll 文件:引用 dll(使用 dllimport 特性)定义与 dll 函数签名匹配的函数原型调用 dll 函数(如同 c# 函数)附加技巧:使用 chars...
    99+
    2024-05-14
    c#
  • 如何构建 Golang RESTful API,并实现 CRUD 操作?
    通过创建 golang 项目并安装必要的包,我们可以构建一个功能齐全的 restful api。它使用 mysql 数据库进行 crud 操作:1. 创建和连接数据库;2. 定义数据结构...
    99+
    2024-05-14
    go crud mysql git golang
  • c#怎么添加类文件
    在c#中添加类文件的步骤:1. 创建新项目,2. 添加新类,3. 为类添加代码,4. 在另一个类中引用新类。using语句引用类文件所在的命名空间;new运算符创建类的新实例;点运算符访...
    99+
    2024-05-14
    c#
  • 使用 C++ 构建高性能服务器架构的最佳实践
    遵循 c++++ 中构建高性能服务器架构的最佳实践可以创建可扩展、可靠且可维护的系统:使用线程池以重用线程,提高性能。利用协程减少上下文切换和内存开销,提升性能。通过智能指针和引用计数优...
    99+
    2024-05-14
    c++ 高性能服务器架构 数据访问
  • c#怎么添加字段
    在 c# 中添加字段包括以下步骤:声明字段:在类或结构中使用 字段类型 字段名; 语法声明字段。访问修饰符:用于限制对字段的访问,如 private、public、protected 和...
    99+
    2024-05-14
    c#
  • c#中怎么添加引用
    c# 中添加引用的方法有四种:使用 nuget 包管理器添加软件包。添加项目引用以包含其他项目。手动编辑项目文件 (.csproj) 以添加引用。从编译器命令行使用 /reference...
    99+
    2024-05-14
    c#
  • c#怎么创建文本文件
    在 c# 中创建文本文件的方法包括:创建 filestream 对象以打开或创建文件。使用 streamwriter 写入文本至文件。关闭 streamwriter 对象释放资源。关闭 ...
    99+
    2024-05-14
    c#
  • c#怎么定义属性
    如何在 c# 中定义属性 属性是一种编程构造,它包含一个 get 访问器和一个 set 访问器,允许以一种类属性的方式访问字段。它们提供了一种安全且封装的方式来访问和修改类的内部数据。 ...
    99+
    2024-05-14
    c#
  • 基于 C++ 的服务器架构的安全性考虑因素
    在设计基于 c++++ 的服务器架构时,安全考虑至关重要:使用 std::string 或 std::vector 避免缓冲区溢出。使用正则表达式或库函数验证用户输入。采用输出转义防止跨...
    99+
    2024-05-14
    安全性 关键词: c++ 服务器架构 c++ lsp
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作