前言

最近看到一些人在问单页面和多页面应用的区别。所以也就输出这一篇短文希望可以给你一个整体的认识。

这里也会大体介绍单页应用实现的核心 —— 前端路由。

单页应用 VS 多页应用

对比图

单页应用(SinglePage Application,SPA)

指只有一个主页面的应用,一开始只需加载一次 js,css 等相关资源。所有的内容都包含在主页面,对每一个功能模块组件化。单页应用跳转,就是切换相关组件,仅刷新局部资源。

多页应用(MultiPage Application,MPA)

指有多个独立的页面的应用,每个页面必须重复加载 js,css 等相关资源。多页应用跳转,需要整页资源刷新。

两者对比表格:

SPA MPA
结构 一个主页面 + 许多模块的组件 许多完整的页面
体验 页面切换快,体验佳;当初次加载文件过多时,需要做相关的调优。 页面切换慢,网速慢的时候,体验尤其不好
资源文件 组件公用的资源只需要加载一次 每个页面都要自己加载公用的资源
适用场景 对体验度和流畅度有较高要求的应用,不利于 SEO(可借助 SSR 优化 SEO) 适用于对 SEO 要求较高的应用
过渡动画 Vue 提供了 transition 的封装组件,容易实现 很难实现
内容更新 相关组件的切换,即局部更新 整体 HTML 的切换,费钱(重复 HTTP 请求)
路由模式 可以使用 hash ,也可以使用 history 普通链接跳转
数据传递 因为单页面,使用全局变量就好(Vuex) cookie 、localStorage 等缓存方案,URL 参数,调用接口保存等
相关成本 前期开发成本较高,后期维护较为容易 前期开发成本低,后期维护就比较麻烦,因为可能一个功能需要改很多地方

单页应用实现核心:前端路由

前端路由的核心:改变视图的同时不会向后端发出请求。

这里我讲讲 vue-router 路由的两种模式:hash&history

1、hash 模式

hash 模式背后的原理是 onhashchange 事件。


  1. window.addEventListener( hashchange ,function(e) {

  2. console.log(e.oldURL);

  3. console.log(e.newURL)

  4. },false);

通过 window.location.hash 属性获取和设置 hash 值。

由于 hash 发生变化的 url 都会被浏览器记录下来,所以浏览器的前进后退可以使用,尽管浏览器没有请求服务器,但是页面状态和 url 关联起来。后来人们称其为前端路由,成为单页应用标配。

hash 模式的特点在于 hash 出现在 url 中,但是不会被包括在 HTTP 请求中,对后端没有影响,不会重新加载页面。

2、history 模式

利用了 HTML5 History Interface 中新增的 pushState()replaceState(),它们提供了对历史记录进行修改的功能。

相关的 API:

history.pushState()


  1. history.pushState(stateObj, title, url);

  1. state:一个与指定网址相关的状态对象, popstate 事件触发时,该对象会传入回调函数。如果不需要可填 null

  2. title:新页面的标题,但是所有浏览器目前都忽略这个值,可填 null

  3. url:新的网址,必须与当前页面处在同一个域。浏览器的地址栏将显示这个网址。

例如:history.pushState(new,new,new.html);

添加上面这个新记录后,浏览器地址栏立刻显示 ~/new.html,但并不会跳转到 new.html,它只是成为 history 中的最新记录。pushState 方法不会触发页面刷新,只是 history 对象变化,地址栏会变。

history.replaceState()


  1. history.replaceState(stateObj, title, url);

参数同 pushState() 一样。

调用该方法,会修改当前的 history 对象记录, history.length 的长度不会改变

history.state

当前 URL 下对应的状态信息。如果当前 URL 不是通过 pushState 或者 replaceState 产生的,那么 history.statenull。当需要 state 和 URL 同步时可以使用 replaceState() 使之同步。

popstate 事件

同一个文档的 history 对象出现变化时,就会触发 popstate 事件。

不同的浏览器在加载页面时处理 popstate 事件的形式存在差异。页面加载时 Chrome 和 Safari 通常会触发 popstate 事件,但 Firefox 则不会。

注意:调用 history.pushState() 或者 history.replaceState() 不会触发 popstate 事件。 popstate 事件只会在浏览器某些行为下触发, 比如点击后退、前进按钮(或者调用 history.back()、history.forward()、history.go()方法)。


单页应用 多页应用的区别相关推荐

  1. 单页应用的优缺点_单页和多页应用程序之间的优缺点

    单页应用的优缺点 Currently, there are two ways of building websites: as multi-page applications (MPAs) or as ...

  2. php分享表单提交到本页的实例

    我们在做表单提交时,一般都要设置表单的action属性,改属性用于指定表单提交到服务器上的哪个页面进行处理,但为空时,表示提交到本页进行处理,即提交给自己.本文章向大家分享表单提交给本页的实例. 实例 ...

  3. Java实现PDF文件转图片(支持单页和多页)

    目录 一.背景 二.maven环境 2.1.依赖 2.2.插件 三.PDF工具类 四.实践 4.1.单页PDF形式的发票转为图片 4.2.多页PDF文档转为图片 结语 一.背景   很多小伙伴们不知道 ...

  4. wordpress网站分类列表页、详情页、单页、模板

    1.公共头部菜单导航 get_header(); 2.wordpress网站面包屑导航 3.wordpress网站侧边栏 4.当前分类顶级分类栏目的分类名_链接(例:当前行业新闻,获取父分类新闻中心栏 ...

  5. python分解word文档为多个_将一个word文档按一页或多页拆分成多个文档

    工作中,有时候碰到需要将一个比较大的word按照指定的页数分割成若干个小的word文档,下面提供分割的方法供参考: 一.按照单页拆分 1.在Word里面打开那个需要分割的文档(假设它的文件名叫做&qu ...

  6. 将一个word文档按一页或多页拆分成多个文档

    工作中,有时候碰到需要将一个比较大的word按照指定的页数分割成若干个小的word文档,下面提供分割的方法供参考: 一.按照单页拆分 1.在Word里面打开那个需要分割的文档(假设它的文件名叫做&qu ...

  7. 单页面应用和多页面应用区别

    单页面应用和多页面应用区别 一.多页面应用 每一次页面跳转的时候,服务器都会给返回一个新的html文档,这种类型的网站也就是多页网站,也叫做多页应用. 多页面具有什么优点呢? 首屏时间快 首屏时间叫做 ...

  8. 计算机组成原理辅助存储器ppt,计算机组成原理存储器PPT资料共60页[共60页]

    <计算机组成原理存储器PPT资料共60页[共60页]>由会员分享,可在线阅读,更多相关<计算机组成原理存储器PPT资料共60页[共60页](60页珍藏版)>请在读根文库上搜索. ...

  9. MVC站点默认页为html页,设置ASP.NET MVC站点默认页为html页

    问题由来 部署了一个Asp.Net MVC的站点,其功能只是作为移动端的服务器,服务器空间里面除了CMS以外就没有其他的页面了.这对于我们来说确实是有点浪费了. 可以放点静态的啥小东西放在上面玩一玩. ...

最新文章

  1. 系列 《使用sklearn进行集成学习——理论》 《使用sklearn进行集成学习——实践》 目录 1 Random Forest和Gradient Tree Boosting参数详解 2 如何调参?
  2. Android-i9023 Root
  3. 重置Oracle密码
  4. Mysql添加用户错误:ERROR 1364 (HY000): Field ‘ssl_cipher‘ doesn‘t have a default value解决方法
  5. iOS导航控制器和Segues
  6. 华为鸿蒙mate,华为MatePad Pro发布亮相!华为首款鸿蒙平板全新体验!
  7. 【例题 8-3 UVA - 1152】4 Values whose Sum is 0
  8. 基于python的网易云音乐下载器
  9. ADC 外电阻分压种种
  10. AspNetPager 分页的详细用法(ASP.NET)
  11. img文件制作linux启动u盘,制作Linux的U盘启动盘
  12. java gwt_gwt中java与js的相互调用 | 学步园
  13. linux est 时间,Linux 时间标准简介
  14. 2021年中国教育行业发展现状及未来发展趋势分析:在校生人数达2.91亿人[图]
  15. apollo如何添加第三方库,以pylon为例
  16. 【嵌入式Linux学习七步曲之第五篇 Linux内核及驱动编程】Linux信号机制分析
  17. 卡西欧计算机算坐标步骤,卡西欧计算器坐标的正反算.doc
  18. skywalking和jpa冲突
  19. 金坷垃-easy (模拟
  20. 抖音怎么养号,老抖音号怎么重新养号

热门文章

  1. 数学/线性代数 {子式,余子式,代数余子式,拉普拉斯展开}
  2. 【网络安全】文件上传漏洞 详解
  3. Linux:安装AnyConnect客户端教程
  4. 【javaweb简单教程】1.搭建Web环境、初识JSP
  5. arp攻击----arpspoof
  6. C语言学习之认识exit()函数
  7. java入门基础掌握单词汇总
  8. [UNR#2]黎明前的巧克力
  9. 【微信小程序】解决点击(bindtap)和长按(bindlongtap)冲突
  10. 解决svn冲突的办法