React学习(⼀)——React出现的历史背景以及前端开发的演变
简介
React 是Facebook 在2013年推出的⼀款前端框架。当他们在开发⼀个简单的功能的时候却⼀再出现“BUG”,所以需要⼀套新的框架⽤来解决传统前端的⼀些问题;
问题描述
开发FaceBook⾸页状态栏,要实时显⽰当前好友请求,消息列表、状态列表;但是当功能上线的时候会出现:如果有⼀条新的消息出现不能够及时的刷新显⽰的数字,但点开⼀条新的消息数字⼜不能够⽴即的修改;
出现原因:
1. 传统的UI操作关注太多细节
2. 应⽤程序状态分散在各处,难以追踪和维护
传统的前端页⾯我们⼀般使⽤Jquery进⾏布局和局部刷新,但是Jquery在操作HTML页⾯需要⼤量的DOM API进⾏DOM操作,关注太多细节
在图⽚上可以看到,通多相当多的dom⽅法才能操作页⾯进⾏局部更新,也就是说你要完成⼀个功能需要关注很多的细节
React出现的历史背景
对于以上的问题,React提出⼀个全新的概念:始终“整体”刷新页⾯
如上图所⽰:
传统的更新⽅式是:当有⼀天新的消息进来之后,我需要获得消息列表的DOM结构,在消息列表的DOM结构中获得已存在的消息记录,在把新增的消息添加到原来的DOM结构中
React 的更新⽅式: 当消息列表中的消息更新(增加、删除、修改);就始终更新消息列表组件,不在关注之前是否存在消息记录
前端开发的演变
静态页⾯阶段 ——> AJAX阶段 ——> 前端 MVC 阶段 ——> SPA 阶段
1. 静态页⾯阶段
为什么前端不学jsp传统的php、jsp等页⾯,都是静态页⾯阶段; ⽹站的前后端开发是⼀体的,即前端代码是后端代码的⼀部分。
1. 后端收到浏览器的请求
2. ⽣成静态页⾯
3. 发送到浏览器
2. AJAX 阶段
AJAX 技术指的是脚本独⽴向服务器请求数据,拿到数据以后,进⾏处理并更新⽹页。整个过程中,后端只是负责提供数据,其他事情都由前端处理。前端不再是后端的模板,⽽是实现了从“获取数据 --> 处理数据 --> 展⽰数据”的完整业务逻辑。
3. 前端MVC阶段
前端代码有了获取数据、处理数据、展⽰数据等功能,因此迫切需要辅助⼯具,⽅便开发者组织代码。这导致了前端 MVC 框架的诞⽣。
2010年,第⼀个前端 MVC 框架 Backbone.js 诞⽣。它基本上是把 MVC 模式搬到了前端,但是只有 M (读写数据)和 V(展⽰数据),没有 C(处理数据)。因为,Backbone 认为前端 Controller 与后端不同,不需要、也不应该处理业务逻辑,只需要处理 UI 逻辑,> > 响应⽤户的⼀举⼀动。所以,数据处理都放在后端,前端只⽤事件响应处理 UI 逻辑(⽤户操作)。
后来,更多的前端 MVC 框架出现。另⼀些框架提出 MVVM 模式,⽤ View Model 代替 Controller。MVVM 模式也将前端应⽤分成三个部分。
Model:读写数据
View:展⽰数据
View-Model:数据处理
View Model 是简化的 Controller,所有的数据逻辑都放在这个部分。它的唯⼀作⽤就是为 View 提供处理好的数据,不含其他逻辑。也就是说,Model 拿到数据以后,View Model 将数据处理成视图层(View)需要的格式,在视图层展⽰出来。
这个模型的特点是 View 绑定 View Model。如果 View Model 的数据变了,View(视图层)也跟着变了;反之亦然,如果⽤户在视图层修改了数据,也⽴刻反映在 View Model。整个过程完全不需要⼿⼯处理。
4. SPA 阶段
前端可以做到读写数据、切换视图、⽤户交互,这意味着,⽹页其实是⼀个应⽤程序,⽽不是信息的纯展⽰。这种单张⽹页的应⽤程序称为 SPA(single-page application)。
所谓 SPA,就是指在⼀张⽹页(single page)上,通过良好的体验,模拟出多页⾯应⽤程序(applicati
on)。⽤户的浏览器只需要将⽹页载⼊⼀次,然后所有操作都可以在这张页⾯上完成,带有迅速的响应和虚拟的页⾯切换。
随着 SPA 的兴起,2010年后,前端⼯程师从开发页⾯(切模板),逐渐变成了开发“前端应⽤”(跑在浏览器⾥⾯的应⽤程序)。
⽬前,最流⾏的前端框架 Vue、Angular、React 等等,都属于 SPA 开发框架。

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。