对SPA单页面的理解,它的优缺点分别是什么,如何实现SPA应用

一、什么是SPA

1、SPA(single-page application),翻译过来就是单页应用

2、SPA是一种网络应用程序或网站的模型,它通过动态重写当前页面来与用户交互,这种方法避免了页面之间切换打断用户体验在单页应用中,所有必要的代码(HTMLJavaScriptCSS)都通过单个页面的加载而检索,或者根据需要(通常是为响应用户操作)动态装载适当的资源并添加到页面页面在任何时间点都不会重新加载,也不会将控制转移到其他页面

3、举个例子来讲就是一个杯子,早上装的牛奶,中午装的是开水,晚上装的是茶,我们发现,变的始终是杯子里的内容,而杯子始终是那个杯子结构如下图

4、我们熟知的JS框架如react,vue,angular,ember都属于SPA

二、SPA和MPA的区别

1、上面大家已经对单页面有所了解了,下面来讲讲多页应用MPA(MultiPage-page application),翻译过来就是多页应用在MPA中,每个页面都是一个主页面,都是独立的当我们在访问另一个页面的时候,都需要重新加载htmlcssjs文件,公共文件则根据需求按需加载如下图

单页应用与多页应用的区别

单页面应用(SPA) 多页面应用(MPA)
组成 一个主页面和多个页面片段 多个主页面
刷新方式 局部刷新 整页刷新
url模式 哈希模式 历史模式
SEO搜索引擎优化 难实现,可使用SSR方式改善 容易实现
数据传递 容易 通过url、cookie、localStorage等传递
页面切换 速度快,用户体验良好 切换加载资源,速度慢,用户体验差
维护成本 相对容易 相对复杂

单页应用优缺点

1、优点:

  • (1)具有桌面应用的即时性、网站的可移植性和可访问性
  • (2)用户体验好、快,内容的改变不需要重新加载整个页面
  • (3)良好的前后端分离,分工更明确

2、缺点:

  • (1)不利于搜索引擎的抓取
  • (2)首次渲染速度相对较慢

三、实现一个SPA

1、原理

  • (1)监听地址栏中hash变化驱动界面变化
  • (2)用pushsate记录浏览器的历史,驱动界面发送变化

2、实现

(1)hash 模式

核心通过监听url中的hash来进行路由跳转

// 定义 Router
class Router {  constructor () {  this.routes = {}; // 存放路由path及callback  this.currentUrl = '';  // 监听路由change调用相对应的路由回调  window.addEventListener('load', this.refresh, false);  window.addEventListener('hashchange', this.refresh, false);  }  route(path, callback){  this.routes[path] = callback;  }  push(path) {  this.routes[path] && this.routes[path]()  }
}  // 使用 router
window.miniRouter = new Router();
miniRouter.route('/', () => console.log('page1'))
miniRouter.route('/page2', () => console.log('page2'))  miniRouter.push('/') // page1
miniRouter.push('/page2') // page2
(2)history模式

history 模式核心借用 HTML5 history apiapi 提供了丰富的 router 相关属性先了解一个几个相关的api

  • (1)history.pushState 浏览器历史纪录添加记录
  • (2)history.replaceState修改浏览器历史纪录中当前纪录
  • (3)history.popStatehistory 发生变化时触发
// 定义 Router
class Router {  constructor () {  this.routes = {};  this.listerPopState()  }  init(path) {  history.replaceState({path: path}, null, path);  this.routes[path] && this.routes[path]();  }  route(path, callback){  this.routes[path] = callback;  }  push(path) {  history.pushState({path: path}, null, path);  this.routes[path] && this.routes[path]();  }  listerPopState () {  window.addEventListener('popstate' , e => {  const path = e.state && e.state.path;  this.routers[path] && this.routers[path]()  })  }
}  // 使用 Router  window.miniRouter = new Router();
miniRouter.route('/', ()=> console.log('page1'))
miniRouter.route('/page2', ()=> console.log('page2'))  // 跳转
miniRouter.push('/page2')  // page2

四、题外话:如何给SPA做SEO

下面给出基于VueSPA如何实现SEO的三种方式

1、SSR服务端渲染

(1)将组件或页面通过服务器生成html,再返回给浏览器,如nuxt.js

2、静态化

目前主流的静态化主要有两种:
(1)一种是通过程序将动态页面抓取并保存为静态页面,这样的页面的实际存在于服务器的硬盘中
(2)另外一种是通过WEB服务器URL Rewrite的方式,它的原理是通过web服务器内部模块按一定规则将外部的URL请求转化为内部的文件地址,一句话来说就是把外部请求的静态地址转化为实际的动态页面地址,而静态页面实际是不存在的。这两种方法都达到了实现URL静态化的效果

3、使用Phantomjs针对爬虫处理

(1)原理是通过Nginx配置,判断访问来源是否为爬虫,如果是则搜索引擎的爬虫请求会转发到一个node server,再通过PhantomJS来解析完整的HTML,返回给爬虫。下面是大致流程图

参考文献

  • (1)https://segmentfault.com/a/1190000019623624
  • (2)https://juejin.cn/post/6844903512107663368
  • (3)https://www.cnblogs.com/constantince/p/5586851.html

(25):SPA单页面的理解相关推荐

  1. [vue] 说说你对SPA单页面的理解,它的优缺点分别是什么?

    [vue] 说说你对SPA单页面的理解,它的优缺点分别是什么? 介绍:SPA应用就是一个web应用,可理解为:是一种只需要将单个页面加载到服务器之中的web应用程序.当浏览器向服务器发出第一个请求时, ...

  2. 通过Blazor使用C#开发SPA单页面应用程序(4) - Ant Design

    通过Blazor使用C#开发SPA单页面应用程序(1) 通过Blazor使用C#开发SPA单页面应用程序(2) 通过Blazor使用C#开发SPA单页面应用程序(3) 前面学习了Blazor的特点.环 ...

  3. [vue] SPA单页面的实现方式有哪些?

    [vue] SPA单页面的实现方式有哪些? 1.监听地址栏中hash变化驱动界面变化2.用pushsate记录浏览器的历史,驱动界面发送变化3.直接在界面用普通事件驱动界面变化它们都是遵循同一种原则: ...

  4. SPA单页面应用首屏加载速度提升方法

    SPA单页面应用首屏加载速度提升方法 首屏加载 计算首屏加载时间公式 解决方法 减少入口文件体积 静态资源本地缓存 UI框架按需加载 避免组件重复打包 图片资源压缩 开启GZip压缩 首屏加载 首屏加 ...

  5. spa单页面应用html缓存问题

    一.背景 浏览器的http请求都有一个缓存机制,简单点说就是同路径同名文件会默认被缓存下来,提升下次访问时的速度,默认只有刷新页面或长时间未访问时才会刷新缓存. 而spa单页面应用是通过路由切换来访问 ...

  6. Java快速开发平台,JEECG 3.7.5 Vue SPA单页面应用版本发布

    JEECG 3.7.5 Vue SPA单页面应用版本发布 导读            ⊙ Vue+ElementUI SPA单页面应用 ⊙Datagrid标签快速切换BootstrapTable列表风 ...

  7. 当spa单页面应用遇上SEO,蛋痛的经历

    spa单页面应用优点当然毋庸置疑:效果酷炫,我在视觉和产品面前无从反驳:性能高速度快,全JS嘛当然快,我在运维和产品面前无言以对:运算分散,异步加载,又省硬件又省流量,我在开发和产品面前彻底投降:JS ...

  8. 通过Blazor使用C#开发SPA单页面应用程序(1)

    2019年9月23--25日 .NET Core 3.0即将在.NET Conf上发布! .NET Core的发布及成熟重燃了.net程序员的热情和希望,一些.net大咖也在积极的为推动.NET Co ...

  9. SPA(单页面应用)和MPA(多页面应用)

    单页面应用 第一次进入页面时会请求一个html文件,刷新清除一下,切换到其他组件,此时路径也相应变化,但是并没有新的html文件请求,页面内容却变化了. 原理:js会感知到url的变化,通过这一点可以 ...

最新文章

  1. 年底送点福利,包邮送55本!Python、大数据、人工智能任你挑!
  2. 物联网是地产行业转型的有力推手
  3. 可持久化线段树(静态)【学习笔记】
  4. python如何爬虫-如何入门 Python 爬虫?
  5. 2010年基于Linux的10大技术趋势
  6. 正则表达式简明使用手册
  7. Struts2 拦截器: 拦截器与过滤器区别
  8. maven项目部署到linux上的奇葩问题
  9. java 类加载生命周期_Java类的加载与生命周期
  10. 摩托车头盔的逆向建模与设计
  11. vant实现Select效果--单选和多选
  12. Google drive谷歌网盘下载副本文件无法调用IDM解决方法
  13. 使用家庭或宿舍宽带将个人电脑变为服务器
  14. 好用的在线音乐网站,有这5个就够了(收藏备用)
  15. 怎样控制animate.css的动画时间
  16. Java读取UTF-8格式txt文件第一行出现乱码及解决;Java读带有BOM的UTF-8文件乱码原因及解决方法(转载)...
  17. 《UML正日薄西山的13个理由》读后感
  18. SNAT实现共享上网(1)
  19. 计算机的未来展望英语作文,展望未来英语作文范文
  20. 项目经理PMO分别是什么?

热门文章

  1. IObit Unlocker删除/解锁占用的文件
  2. 存储调研:BeeGFS并行文件系统体系结构
  3. 转:浅谈程序员的英语学习
  4. 嵌入式开发要难于单片机开发?
  5. 7-16 然后是几点(15 分)
  6. 【笔记】element-ui el-select使用需要v-model绑定值为字符串,而选中后事件获取对象
  7. Vue 过滤器、计算属性、侦听器 图解版 一目了然
  8. ROM、PROM、EPROM、EEPROM、FLASH ROM
  9. css小游戏,js小游戏,Flex Box青蛙、冒险游戏、设计模式游戏等
  10. LAMP环境让php支持pdo_mysql