单页应用 多页应用的区别
前言
最近看到一些人在问单页面和多页面应用的区别。所以也就输出这一篇短文希望可以给你一个整体的认识。
这里也会大体介绍单页应用实现的核心 —— 前端路由。
单页应用 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
事件。
window.addEventListener( hashchange ,function(e) {
console.log(e.oldURL);
console.log(e.newURL)
},false);
通过
window.location.hash
属性获取和设置hash
值。
由于 hash 发生变化的 url 都会被浏览器记录下来,所以浏览器的前进后退可以使用,尽管浏览器没有请求服务器,但是页面状态和 url 关联起来。后来人们称其为前端路由,成为单页应用标配。
hash 模式的特点在于 hash 出现在 url 中,但是不会被包括在 HTTP 请求中,对后端没有影响,不会重新加载页面。
2、history 模式
利用了 HTML5 History Interface 中新增的
pushState()
和replaceState()
,它们提供了对历史记录进行修改的功能。
相关的 API:
history.pushState()
history.pushState(stateObj, title, url);
state:一个与指定网址相关的状态对象,
popstate
事件触发时,该对象会传入回调函数。如果不需要可填null
。title:新页面的标题,但是所有浏览器目前都忽略这个值,可填
null
。url:新的网址,必须与当前页面处在同一个域。浏览器的地址栏将显示这个网址。
例如:
history.pushState(new,new,new.html);
添加上面这个新记录后,浏览器地址栏立刻显示 ~/new.html
,但并不会跳转到 new.html
,它只是成为 history
中的最新记录。pushState
方法不会触发页面刷新,只是 history
对象变化,地址栏会变。
history.replaceState()
history.replaceState(stateObj, title, url);
参数同 pushState()
一样。
调用该方法,会修改当前的 history
对象记录, history.length
的长度不会改变
history.state
当前 URL 下对应的状态信息。如果当前 URL 不是通过 pushState
或者 replaceState
产生的,那么 history.state
是 null
。当需要 state 和 URL 同步时可以使用 replaceState()
使之同步。
popstate 事件
同一个文档的
history
对象出现变化时,就会触发popstate
事件。
不同的浏览器在加载页面时处理 popstate
事件的形式存在差异。页面加载时 Chrome 和 Safari 通常会触发 popstate 事件,但 Firefox 则不会。
注意:调用 history.pushState()
或者 history.replaceState()
不会触发 popstate
事件。 popstate
事件只会在浏览器某些行为下触发, 比如点击后退、前进按钮(或者调用 history.back()、history.forward()、history.go()
方法)。
单页应用 多页应用的区别相关推荐
- 单页应用的优缺点_单页和多页应用程序之间的优缺点
单页应用的优缺点 Currently, there are two ways of building websites: as multi-page applications (MPAs) or as ...
- php分享表单提交到本页的实例
我们在做表单提交时,一般都要设置表单的action属性,改属性用于指定表单提交到服务器上的哪个页面进行处理,但为空时,表示提交到本页进行处理,即提交给自己.本文章向大家分享表单提交给本页的实例. 实例 ...
- Java实现PDF文件转图片(支持单页和多页)
目录 一.背景 二.maven环境 2.1.依赖 2.2.插件 三.PDF工具类 四.实践 4.1.单页PDF形式的发票转为图片 4.2.多页PDF文档转为图片 结语 一.背景 很多小伙伴们不知道 ...
- wordpress网站分类列表页、详情页、单页、模板
1.公共头部菜单导航 get_header(); 2.wordpress网站面包屑导航 3.wordpress网站侧边栏 4.当前分类顶级分类栏目的分类名_链接(例:当前行业新闻,获取父分类新闻中心栏 ...
- python分解word文档为多个_将一个word文档按一页或多页拆分成多个文档
工作中,有时候碰到需要将一个比较大的word按照指定的页数分割成若干个小的word文档,下面提供分割的方法供参考: 一.按照单页拆分 1.在Word里面打开那个需要分割的文档(假设它的文件名叫做&qu ...
- 将一个word文档按一页或多页拆分成多个文档
工作中,有时候碰到需要将一个比较大的word按照指定的页数分割成若干个小的word文档,下面提供分割的方法供参考: 一.按照单页拆分 1.在Word里面打开那个需要分割的文档(假设它的文件名叫做&qu ...
- 单页面应用和多页面应用区别
单页面应用和多页面应用区别 一.多页面应用 每一次页面跳转的时候,服务器都会给返回一个新的html文档,这种类型的网站也就是多页网站,也叫做多页应用. 多页面具有什么优点呢? 首屏时间快 首屏时间叫做 ...
- 计算机组成原理辅助存储器ppt,计算机组成原理存储器PPT资料共60页[共60页]
<计算机组成原理存储器PPT资料共60页[共60页]>由会员分享,可在线阅读,更多相关<计算机组成原理存储器PPT资料共60页[共60页](60页珍藏版)>请在读根文库上搜索. ...
- MVC站点默认页为html页,设置ASP.NET MVC站点默认页为html页
问题由来 部署了一个Asp.Net MVC的站点,其功能只是作为移动端的服务器,服务器空间里面除了CMS以外就没有其他的页面了.这对于我们来说确实是有点浪费了. 可以放点静态的啥小东西放在上面玩一玩. ...
最新文章
- 系列 《使用sklearn进行集成学习——理论》 《使用sklearn进行集成学习——实践》 目录 1 Random Forest和Gradient Tree Boosting参数详解 2 如何调参?
- Android-i9023 Root
- 重置Oracle密码
- Mysql添加用户错误:ERROR 1364 (HY000): Field ‘ssl_cipher‘ doesn‘t have a default value解决方法
- iOS导航控制器和Segues
- 华为鸿蒙mate,华为MatePad Pro发布亮相!华为首款鸿蒙平板全新体验!
- 【例题 8-3 UVA - 1152】4 Values whose Sum is 0
- 基于python的网易云音乐下载器
- ADC 外电阻分压种种
- AspNetPager 分页的详细用法(ASP.NET)
- img文件制作linux启动u盘,制作Linux的U盘启动盘
- java gwt_gwt中java与js的相互调用 | 学步园
- linux est 时间,Linux 时间标准简介
- 2021年中国教育行业发展现状及未来发展趋势分析:在校生人数达2.91亿人[图]
- apollo如何添加第三方库,以pylon为例
- 【嵌入式Linux学习七步曲之第五篇 Linux内核及驱动编程】Linux信号机制分析
- 卡西欧计算机算坐标步骤,卡西欧计算器坐标的正反算.doc
- skywalking和jpa冲突
- 金坷垃-easy (模拟
- 抖音怎么养号,老抖音号怎么重新养号
热门文章
- 数学/线性代数 {子式,余子式,代数余子式,拉普拉斯展开}
- 【网络安全】文件上传漏洞 详解
- Linux:安装AnyConnect客户端教程
- 【javaweb简单教程】1.搭建Web环境、初识JSP
- arp攻击----arpspoof
- C语言学习之认识exit()函数
- java入门基础掌握单词汇总
- [UNR#2]黎明前的巧克力
- 【微信小程序】解决点击(bindtap)和长按(bindlongtap)冲突
- 解决svn冲突的办法