首页 > 网络编程 > JavaScript > 正文

基于vue和react的spa进行按需加载的实现方法_vue.js

2018-10-13 20:27:25

基于vue和react的spa进行按需加载

由于最近打算将所有的管理系统采用同一套登陆方法,然后在登陆后进行系统的切换选择,不需要每个系统都去重新登陆一次,所以前端这边思考将所有的系统用一套spa的应用进行构建,但是各个系统的合并之后,打包后的代码应该是相当大的,单页需要一次性加载所有系统的资源,显得不合实际,所以打算将不同系统的资源进行分离,再选择后在加载该系统的相应资源。自己发现这个业务和每个系统的路由比较类似,因此将系统的配置基于vue-router或者react-router的基础进行按需加载处理。因此自己了解了一下按需加载的应用和配置方案。

基于该业务大家有其他解决方案欢迎交流( _O_ )

按需加载

随着单页应用的发展,整个系统的所有功能都集合在一个页面,该页面一次性加载所有的资源,随着系统的不断扩展,因此所加载的资源会不断的增大,虽然经过压缩处理,大大的减小了资源的内容量,但是不能从本质上减小资源内容的增多。

其实我们的模块对应不同的资源,就类似之前所做的多页系统,不同的页面加载对应的资源文件,所以可以参考之前的的多页系统的做法,在单页系统中根据不同的模块加载其对应的资源文件。就是用户当前需要用什么功能就只加载这个功能对应的代码,也就是所谓的按需加载。

如何按需加载

在单页应用做按需加载,一般采用以下原则

  • 把整个系统划分成一个个小功能,再按照功能的相关程度划分为几类。
  • 把每一类合并为一个Chunk,按需加载对应的Chunk
  • 对于首屏看到的内容直接放到入口Chunk中,以降低网页首次加载资源的个数
  • 对于其他的模块可以做按需加载。

被分割出去的代码的加载需要一定的机制去触发,也就是当用户即将操作到对应的功能时再去加载。被分割出去的代码的加载时机需要开发者根据自己系统的需求去衡量确定。
因为被分割出去的代码加载也需要一定的时间,所以可以提前做预加载处理。

import()

在开始下面的案例之前先了解一下import(),这里的import()不同于引入模块的import xxx from 'xxx',这里的import是指一个动态加载模块的函数,传入的参数就是相应的模块,但是import()会返回一个Promise对象,因此可以在import()完成后根据其状态进行处理。

//egimport('/component/details').then(mod=>{  console.log(mod)},error=>{  console.log(error)})

vue按需加载的应用

1.模块分割

根据自己系统的情况,个人根据vue-router的模块来进行分割,

//roter配置的分割代码import Vue from 'vue'import Router from 'vue-router'const listnav=()=> import('@/components/listnav')const adminav=()=> import('@/components/adminav')Vue.use(Router)const router = new Router({  routes:[{    path:'/listnav',    name:'listnav',    component:listnav  },  {    path:'/adminav',    name:'adminav',    component:adminav  }  ]})export default router

2.webpack输出文件配置

//webpack.base.conf.jsmoudle.exports = {  entry:{    app:'./src/main.js'  },  output:{    path:"../dist",    filename:'js/[name].js',    chunkFilename:'js/[name].js'  }}

react按需加载应用

1,模块分割

同样模块分割可采用react-router进行划分

//router配置分割代码import React, {PureComponent, Component ,createElement} from 'react';import {HashRouter as Router, Route,Link,withRouter} from 'react-router-dom';import Home from "../component/home"function getAsyncComponent(load) { return class AsyncComponent extends PureComponent {  constructor(props) {   super(props);  }  componentDidMount() {   // 在高阶组件 DidMount 时才去执行网络加载步骤   load().then(({default: component}) => {   // 代码加载成功,获取到了代码导出的值,调用 setState 通知高阶组件重新渲染子组件    this.setState({     component,    })   });  }  render() {   const {component} = this.state || {};   // component 是 React.Component 类型,需要通过 React.createElement 生产一个组件实例   return component ? createElement(component) : null;  } }}const Routes = () =>(  <HashRouter>    <Route path="/home/:test" exact component={Home}/>    <Route path='/details/:id' component={getAsyncComponent(     // 异步加载函数,异步地加载 details组件     () => import('../component/details')    )}/>  </HashRouter>)export default Routers;

2.webpack输出文件配置

//webpack.base.config.jsmodule.exports = {  entry:{    main: "../src/index.js", //入口文件  },  output:{    path:"../dist",//出口文件    filename:"js/[name].js",    chunkFilename:"js/[name].js",    publicPath: ''  }}

3.按需加载组件中的props传递

在按需加载划分后,按需加载的组件不能接收到传递来的props,因此不能通过this.props.match.params来获取router配置时所带入的参数。

解决方法利用react-router中的withRouter

可以在按需加载的组件中进行配置处理

//component/details.jsimport React, { Component } from 'react';import {withRouter} from 'react-router-dom';class Details extends Component {  constructor(props) {    super(props);  }  render() {    console.log(this.props)    return (      <div></div>    )  }}export default withRouter(Details);

参考链接

vue-router路由懒加载 [ https://router.vuejs.org/zh/guide/advanced/lazy-loading.html]

React按需加载[ http://webpack.wuhaolin.cn/4%E4%BC%98%E5%8C%96/4-12%E6%8C%89%E9%9C%80%E5%8A%A0%E8%BD%BD.html]

总结

以上所述是小编给大家介绍的基于vue和react的spa进行按需加载的实现方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

您可能感兴趣的文章:

  • 在 React、Vue项目中使用SVG的方法
  • 浅谈vue,angular,react数据双向绑定原理分析
  • 前端框架学习总结之Angular、React与Vue的比较详解
  • VueJs与ReactJS和AngularJS的异同点
  • Vue.js 2.0 和 React、Augular等其他前端框架大比拼
  • 相关标签:JavaScript
  • 本文发布HTML5中文学习网 ,转载请注明出处,感谢您!
  • 相关文章


  • 曝网友假装外国人写投诉信 ofo秒退押金并回函致歉
  • 苹果市值缩水逾2000亿美元 遭多家投行下调目标价
  • Asp.net Core与类库读取配置文件信息的方法_实用技巧
  • asp.net在Repeater嵌套的Repeater中使用复选框详解_实用技巧
  • 利用IIS调试ASP.NET网站程序的完整步骤_实用技巧
  • Asp.Net Core轻松学习系列之配置文件_实用技巧
  • ASP.NET 页生命周期概述(小结)_实用技巧
  • 详解ASP.NET Core WebApi 返回统一格式参数_实用技巧
  • 2018年网络流行语有哪些?2018年十大网络流行语盘点
  • 华为首席财务官孟晚舟被暂扣 深圳市政府要求加方立即放人!
  • 独孤九贱(4)_PHP视频教程

    江湖传言:PHP是世界上最好的编程语言。真的是这样吗?这个梗究竟是从哪来的?学会本课程,你就会明白了。 PHP中文网出品的PHP入门系统教学视频,完全从初学者的角度出发,绝不玩虚的,一切以实用、有用...

    独孤九贱(5)_ThinkPHP5视频教程

    ThinkPHP是国内最流行的中文PHP开发框架,也是您Web项目的最佳选择。《php.cn独孤九贱(5)-ThinkPHP5视频教程》课程以ThinkPHP5最新版本为例,从最基本的框架常识开始,将...

    独孤九贱(1)_HTML5视频教程

    《php.cn原创html5视频教程》课程特色:php中文网原创幽默段子系列课程,以恶搞,段子为主题风格的php视频教程!轻松的教学风格,简短的教学模式,让同学们在不知不觉中,学会了HTML知识。 ...

    ThinkPHP5实战之[教学管理系统]

    本套教程,以一个真实的学校教学管理系统为案例,手把手教会您如何在一张白纸上,从零开始,一步一步的用ThinkPHP5框架快速开发出一个商业项目。

    PHP入门视频教程之一周学会PHP

    所有计算机语言的学习都要从基础开始,《PHP入门视频教程之一周学会PHP》不仅是PHP的基础部分更主要的是PHP语言的核心技术,是学习PHP必须掌握的内容,任何PHP项目的实现都离不开这部分的内容,通...

    作者信息

    kevin

    永远在学习的路上!

    相关教程

  • javascript初级视频教程 javascript初级视频教程
  • jquery 基础视频教程 jquery 基础视频教程
  • javascript三级联动视频教程 javascript三级联动视频教程
  • 独孤九贱(3)_JavaScript视频教程 独孤九贱(3)_JavaScript视频教程
  • 独孤九贱(6)_jQuery视频教程 独孤九贱(6)_jQuery视频教程
  • 热门教程