广告
返回顶部
首页 > 资讯 > 前端开发 > JavaScript >JavaScript中对于SPA单页面的理解
  • 613
分享到

JavaScript中对于SPA单页面的理解

JSSPA单页面JSSPA单页面应用 2023-02-23 11:02:46 613人浏览 独家记忆
摘要

目录一、什么是SPA二、SPA和MPA的区别单页应用与多页应用的区别单页应用优缺点三、实现一个SPA四、如何给SPA做SEO 一、什么是SPA SPA(single-page app

一、什么是SPA

SPA(single-page application),翻译过来就是单页应用SPA是一种网络应用程序或网站的模型,它通过动态重写当前页面来与用户交互,这种方法避免了页面之间切换打断用户体验在单页应用中,所有必要的代码(htmljavascriptCSS)都通过单个页面的加载而检索,或者根据需要(通常是为响应用户操作)动态装载适当的资源并添加到页面页面在任何时间点都不会重新加载,也不会将控制转移到其他页面举个例子来讲就是一个杯子,早上装的牛奶,中午装的是开水,晚上装的是茶,我们发现,变的始终是杯子里的内容,而杯子始终是那个杯子结构如下图

我们熟知的js框架React,Vue,angular,ember都属于SPA

二、SPA和MPA的区别

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

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

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

单页应用优缺点

优点:

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

缺点:

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

三、实现一个SPA

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

实现

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  

history模式

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

  • history.pushState浏览器历史纪录添加记录
  • history.replaceState修改浏览器历史纪录中当前纪录
  • 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的三种方式

SSR服务端渲染

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

静态化

目前主流的静态化主要有两种:

(1)一种是通过程序将动态页面抓取并保存为静态页面,这样的页面的实际存在于服务器的硬盘中

(2)另外一种是通过WEB服务器的URL Rewrite的方式,它的原理是通过web服务器内部模块按一定规则将外部的URL请求转化为内部的文件地址,一句话来说就是把外部请求的静态地址转化为实际的动态页面地址,而静态页面实际是不存在的。

这两种方法都达到了实现URL静态化的效果

使用Phantomjs针对爬虫处理

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

到此这篇关于JavaScript中对于SPA单页面的理解的文章就介绍到这了,更多相关JS SPA单页面内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: JavaScript中对于SPA单页面的理解

本文链接: https://www.lsjlt.com/news/197318.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • JavaScript中对于SPA单页面的理解
    目录一、什么是SPA二、SPA和MPA的区别单页应用与多页应用的区别单页应用优缺点三、实现一个SPA四、如何给SPA做SEO 一、什么是SPA SPA(single-page app...
    99+
    2023-02-23
    JS SPA单页面 JS SPA单页面应用
  • JavaScript中怎么实现SPA单页面
    这篇“JavaScript中怎么实现SPA单页面”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“JavaScript中怎么实现...
    99+
    2023-07-05
  • 怎么理解javascript基于对象的特性
    JavaScript是一门基于对象的编程语言。它充分利用了面向对象编程(OOP)的思想和原则。通过这种方式,它将代码组织成易于理解和重用的块,进一步提高了开发人员的效率。在这篇文章中,我们将探讨如何理解JavaScript的基于对象的特性。...
    99+
    2023-05-14
  • JavaScript中如何理解单体内置对象
    这篇文章将为大家详细讲解有关JavaScript中如何理解单体内置对象,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。ECMA-262 对内置对象的定义是「由...
    99+
    2022-10-19
  • 关于对MongoDB索引的一些简单理解
    目录索引简介1.语法准备 2.数据准备: 3.索引 3.1 唯一索引 3.2 单键索引 3.3 多键索引 3.4 复合索引 3.5 交叉索引 3.6 部分索引 3.7覆盖索引 3.8...
    99+
    2022-11-12
  • 在Django同1个页面中的多表单处理详解
    快速上手Django实现项目 近期公司在做1个海淘的项目,APP为pylot。由于时间比较赶,加上隔壁那哥们不在,只能自己挑大梁了。结果,当项目做出来之后,被领导狠狠的批了一顿,说怎么用django写,你能...
    99+
    2022-06-04
    表单 详解 页面
  • 对于Python中RawString的理解介绍
    总结 1、'''作用: 可以表示 "多行注释" 、"多行字符串" 、"其内的单双引号不转义" 2、r 代表的意思是: raw 3、r 只对其内的反斜杠起作用(注意单个 的问题) raw string 有什...
    99+
    2022-06-04
    Python RawString
  • 正则表达式中关于对原生字符串的简单理解
    在正则表达式中,有些字符是有特殊意义的字符。因此如果想要匹配这些字符,那么就必须使用反斜杠进行转义。比如$代表的是以...结尾,如果想要匹配$,那么就必须使用\$。示例代码如下: t...
    99+
    2022-11-13
    正则表达式原生字符串 字符串的正则表达式 字符串和正则表达式
  • 如何理解页面元素的绝对定位和相对定位
    这篇文章主要介绍“如何理解页面元素的绝对定位和相对定位”,在日常操作中,相信很多人在如何理解页面元素的绝对定位和相对定位问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”如何理解页面元素的绝对定位和相对定位”的疑...
    99+
    2023-06-08
  • 关于对python中self的深入理解
    假设有一个类nameMain(), 如最下面代码 类 : 一个抽象的模板。可以理解为抽象设计图类名:类的名字。查看/实现方式 :print(nameMain)或者print(self...
    99+
    2022-11-11
  • 如何理解JavaScript中的对象
    如何理解JavaScript中的对象,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。 JavaScript中对象的简介...
    99+
    2022-10-19
  • php中关于hook(钩子)的简单理解
    假设你有一套登录注册业务。一开始很简单,老板说只需要常规的注册登录就行。 但是到了后面,接口被刷,老板然你在注册登录前加个验证码 然后没过多久,老板又说,当用户注册时,我们给用户的邮箱或者手机发一条欢迎短信或者邮件吧 还没过上多久,老...
    99+
    2023-09-18
    java 开发语言
  • Javascript中Null和undefined的简单理解
    目录前言undefinedNull附:实际应用总结前言 在 JavaScript 中有两种表达“无”的方式,那就是使用undefined和null。 unde...
    99+
    2022-11-13
  • Python中关于面向对象中继承的详细讲解
    目录1.继承2.单继承3.多继承4.子类重写父类的同名属性和方法5.子类调用父类同名属性和方法6.多层继承7.调用父类方法super()8.案例1.继承 在程序中,继承描述的是多个类...
    99+
    2022-11-12
  • Python中关于面向对象概念的详细讲解
    面向对象编程的2个非常重要的概念: 类和对象 对象是面向对象编程的核心,在使用对象的过程中,为了将具有共同特征和行为的一组对象抽象定义,提出了另外一个新的概念——类。 类用来描述具有...
    99+
    2022-11-12
  • 如何在JavaScript面试中展示对Go语言并发的理解?
    在现代的软件开发领域,面试已经成为了招聘流程中不可或缺的一部分。在JavaScript面试中,对Go语言并发的理解是一项重要的技能,而如何在面试中展示这种理解则是一项挑战。在本文中,我们将介绍如何在JavaScript面试中展示对Go语言并...
    99+
    2023-06-23
    并发 javascript 面试
  • Python 面试中,如何评估候选人对 javascript 函数的理解?
    Python 面试中,如何评估候选人对 JavaScript 函数的理解? Python 和 JavaScript 都是非常流行的编程语言,它们都有着广泛的应用场景。在招聘 Python 开发人员的时候,考察候选人对 JavaScript ...
    99+
    2023-08-22
    面试 javascript 函数
  • 如何理解JS中的面向对象
    这篇文章主要讲解了“如何理解JS中的面向对象”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“如何理解JS中的面向对象”吧!在讲这个之前我们先来说说类,了解面向...
    99+
    2022-10-19
  • 对PyTorch中inplace字段的全面理解
    例如 torch.nn.ReLU(inplace=True) inplace=True 表示进行原地操作,对上一层传递下来的tensor直接进行修改,如x=x+3; ...
    99+
    2022-11-12
  • 一文理解JavaScript中的单例模式
    JS 单例模式是一种常用的设计模式,它可以保证一个类只有一个实例。这种模式主要用于管理全局变量,避免命名冲突和重复加载,同时也可以减少内存占用,提高代码的可维护性和可扩展性。价值场景JS 单例模式通常适用于以下场景:管理全局变量使用单例模式...
    99+
    2023-05-14
    单例模式 前端 JavaScript 面试
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作