当前位置:网站首页>Internship Road: Documenting Confusion in My First Internship Project
Internship Road: Documenting Confusion in My First Internship Project
2022-08-03 15:15:00 【The..Fuir】
生有热烈,藏与俗常
1.什么是路由懒加载
也叫延迟加载,即在需要的时候进行加载,随用随载.
官方解释:
1:当打包构建应用时,JavaScript 包会变得非常大,影响页面加载. 2:如果我们能把不同路由对应的组件分割成不同的代码块,然后当路由被访问的时候才加载对应组件,这样就更加高效了.
Officials want to express the meaning of
- 首先,我们知道路由中通常会定义很多不同的页面
- This page will be packaged where?In general is in ajs文件中
- But page so much,All files in ajs文件中,Will inevitably cause the page will be very big
- If we one-time request from the server down the page,可能需要花费一定的时间,Even without the user's computer would be a brief blank
- 如何避免这种情况?Use routing lazy loading can be
Went on to explain reason?
1:像vue这种单页面应用,如果没有应用懒加载,运用webpack打包后的文件将会异常的大.
2:造成进入首页时,需要加载的内容过多,时间过长,会出啊先长时间的白屏,即使做了loading也是不利于用户体验.
3:而运用懒加载则可以将页面进行划分,需要的时候加载页面,可以有效的分担首页所承担的加载压力,减少首页加载用时
路由懒加载做了什么
Routing lazily routing is the main purpose of the corresponding component packaged into one by onejs代码块
As long as at the time of this route is access to the,才加载对应的组件2、路由懒加载的使用
在使用之前,Let's look at how the original code loading route
import Vue from "vue"; import VueRouter from "vue-router"; import Home from "@/views/Home"; import About from "@/views/About"; import User from "@/views/User"; Vue.use(VueRouter); const routes = [ { path: "/", name: "Home", component: Home, }, { path: "/about", name: "About", component: About }, { path: "/user/:userId", name: "User", component: User } ];
We see from the beginning we have imported the routing of the corresponding component,If you need to import components very much,Then loading the page will be relatively slow,We'll look at file pack out this way
We see this way to pack out file only2个js文件,After we load the page,需要把这2A file all finished loading,The page will display,If the code quantity too much,Then page response is slow,To the user experience very bad
Next, we use routing lazy loading
import Vue from "vue"; import VueRouter from "vue-router"; Vue.use(VueRouter); // New routing lazy loading code const Home = () => import('../views/Home') const About = () => import('../views/About') const User = () => import('../views/User') const routes = [ { path: "/", name: "Home", component: Home, }, { path: "/about", name: "About", component: About }, { path: "/user/:userId", name: "User", component: User } ];
我们看到,在路由配置中什么都不需要改变,You just need to make as usual,Just before that declares a variable,Variables used in the arrow function to import components,使用起来非常简单.
Use routing pack out in the form of the lazy loading file structure is as follows:
We can see more than the original way3个js文件,This is because our code above3A component using the routing lazy loading,这3个jsOnly routing is access to a file to load,Can save a lot of load time
So we recommend using more routing lazy loading way to load the routing
3.Several methods of realizing routing lazy loading
路由懒加载:即:只有在这个路由被访问到的时候,才加载对应的组件,否则不加载!
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:The method of introducing component directly,import是ES6的一个语法标准,If you need a browser compatibility,需要转化成es5的语法. 2:推荐使用这种方式,但是注意wepack的版本>2.4 3:vueThe official document is also used in theimport实现路由懒加载 4:The above statement import,下面直接使用
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(/* webpackChunkName: 'ImportFuncDemo' */ '../components/Foo') // const Aoo = () => import(/* webpackChunkName: 'ImportFuncDemo' */ '../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的文件名
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的比较(了解)
1:import 是解构过程并且是编译时执行 2:require 是赋值过程并且是运行时才执行,也就是异步加载 3:require的性能相对于import稍低,因为require是在运行时才引入模块并且还赋值给某个变量
边栏推荐
猜你喜欢
随机推荐
2022-08-03日报:汪林望 vs 刘铁岩:AI、机器学习在材料科学研究中能发挥哪些作用?
2021年12月电子学会图形化四级编程题解析含答案:森林运动会
MySQL性能优化的'4工具+10技巧'
【周报】2022年7月31日
rust编程基础
LeetCode169:多数元素
币圈提款机:Solana钱包出现未知安全漏洞 大量用户数字资产被盗
devops-2:Jenkins的使用及Pipeline语法讲解
夜神浏览器fiddler抓包
又有大厂员工连续加班倒下/ 百度搜狗取消快照/ 马斯克生父不为他骄傲...今日更多新鲜事在此...
Flink作业调度详解
sql注入之盲注(纯原创)
Currency ATM: Solana Wallet Has Unknown Security Vulnerability, A Large Number Of Users' Digital Assets Are Stolen
LeetCode136:只出现一次的数字
跨桌面端之组件化实践
php类的析构函数:__destruct
What are the visual database design software _ database visual programming
方舟开服教程win
问题3:你提交的缺陷开发认为这不是BUG,怎么办?
PHP高级面试题 - 第二天