4.9号总结

一、react与vue2、vue3对比区别和共同点:

1、语法风格:

react语法少、难度大一点;

vue语法多,难度小;

使用vue是在操作vue,使用react是在操作js

2、视图风格

vue采用template字符串模板,更贴近html,欠缺灵活;使用render函数也可以写jsx语法;

react采用jsx语法,更类似js,限制多。

3、组件风格

vue2 选项是API,vue3组合式api

react 16.8后提供函数组件写法

4、状态管理风格:

4.1、vue 采用vuex或pinia (vuex store或者pinia store直接管理数据)

4.2、react采用redux(单向数据流)或mobx(响应式数据)

4.3、异步处理的不同:在 Redux 中,异步处理通常需要使用中间件来处理异步操作。而在 Vuex 和 Pinia 中,异步操作可以通过 actions 处理。而在 Mobx 中,则可以使用 async/await 或 reaction 函数来处理异步操作。

4.4、开销和复杂性的不同:Redux 和 Mobx 都需要在应用程序中进行额外的设置和配置,并且在处理大量数据时可能会导致性能问题。而 Vuex 和 Pinia 的设置和配置相对简单,并且在大多数情况下可以处理大量数据。

共同点:

虚拟dom,diff动态数据比对,数据驱动,生命周期,

二、SEO

框架:

ssr:服务器端渲染

vue nuxt.js

react next.js

TDK (title,description,key)

框架外:

预渲染

语义化标签的使用

h1标签里不嵌套其他标签

sitemap 网站地图 xml格式或者txt格式

微数据结构化

三、http1、http2、http3

http1

http1.1缺陷

高延迟-队头阻塞:当顺序发送的一个请求因为某种原因被阻塞,后面的请求一并被阻塞;(解决方案:将同一页面的资源分散到不同域名下,减少请求数量,内联一些资源,合并小文件减少资源数)

无状态性:协议对于链接状态没有记忆,纯净的http没有cookie。

明文传输:(没有加密,中途可能被篡改和劫持,不安全)

不支持服务端推送

SPDY协议:google基于http1.1的改进版

特性:

多路复用 - 解决队头阻塞(允许在一个连接上无限制并发流,请求在一个通道上,TCP效率更高。更少的网络连接,发出更密集的包)

头部压缩 - 解决巨大的http头部(专门的Hpack算法,每次请求和响应只发送差异头部,一般可达到50%-90%的高压缩率)

请求优先级 - 先获取重要数据(因带宽原因,网络通道被非关键资源堵塞时,高优先级的请求会被优先处理)

服务端推送 - 填补空白(serverPush,可以让服务端主动把资源推送给客户端,客户端有权利选择是否接收)

提高安全性:使用https进行加密传输

http2

http2基于spdy,专注于性能,最大的一个目标是在用户和网站之间只用一个连接;

新增特性:

二进制分帧 - 二进制性能增强的核心。(http2没有改变http1的语义,只是在应用层使用二进制分帧方式传输。因此,也引入了新的额通信单位:帧、消息、流);

分帧的好处:服务器单位时间内接收的请求数变多,可以提高并发数。最重要的是为多路复用提供了底层支持。

多路复用 - 解决串行文件的文件传输和连接数过多。(一个域名对应一个链接,一个流代表了一个完整的请求-响应过程。帧是最小的数据单位,每个帧都会标识出属于哪个流,流也就是多个帧组成的数据流,多路复用,就是在一个tcp连接中可以存在多个流)

http2缺陷:

  1. TCP以及TCP+TLS建立连接的延时
  2. TCP的队头阻塞并没有彻底解决;
  3. 多路复用导致服务器压力上升;
  4. 多路复用容易timeout

http3

google在推出SPDY的时候就意识到了这些问题,于是搞了UDP协议的QUIC协议。这个就是HTTP3;

主要特点:

改进拥塞控制,可靠传输;

快速握手

集成TLS1.3加密

多路复用:一个tcp连接存在多个流(每个流又分为很多帧)

连接迁移:涉及到负载均衡

四、TCP和UDP区别

1、连接

TCP是面向连接的传输层协议,传输数据前要先建立连接;

UDP不需要连接,即可传输协议;

2、服务对象:

TCP是一对一的两点服务,即一条连接只有两个端点;

UDP支持一对一、一对多、多对多的交互通信;

3、可靠性:

TCP是可靠交付数据的,数据可以无差错、不丢失、不重复、按需到达;

UDP是尽最大努力交付,不保证可靠交付数据;

4、拥塞控制、流量控制

TCP有拥塞控制和流量控制机制,保证数据传输的安全性;

UDP则没有,即使网络非常拥堵了,也不会影响UDP的发送速率;

5、首部开销

TCP首部长度较长,会有一定的开销,首部在没有使用选项字段时是20个字节,如果使用了选项则会变长;

UDP首部只有8个字节,并且是固定不变的,开销较小;

6、传输方式

TCP是流式传输,没有边界,但保证顺序和可靠;

UDP是一个包一个包的发送,是有边界的,但是可能会丢包和乱序;

7、分片不同

TCP的数据大小如果大于MSS大小,则会在传输层进行分片,目标主机收到后,也同样在传输层组装TCP数据包,如果中途丢失一个分片,只需要传输丢失的这个分片;

UDP的数据大小如果大于MTU大小,则会在IP层进行分片,目标主机收到后,在IP层组装完数据,接着再传给传输层;

TCP和UDP应用场景

  1. 由于TCP是面向连接,能保证数据的可靠性交付,因此经常用于
    1. FTP文件传输
    2. HTTP/HTTPS
  2. 由于UDP面向无连接,它可以随时发送数据,再加上UDP本身的处理既简单又高效,因此经常用于:
    1. 包总量较少的通信,如DNS、SNMP等;
    2. 视频、音频等多媒体通信
    3. 广播通信

待学习:

react Context API的使用

taro 跨框架跨平台解决方案

相关推荐
everyStudy24 分钟前
JS中判断字符串中是否包含指定字符
开发语言·前端·javascript
城南云小白24 分钟前
web基础+http协议+httpd详细配置
前端·网络协议·http
前端小趴菜、25 分钟前
Web Worker 简单使用
前端
web_learning_32128 分钟前
信息收集常用指令
前端·搜索引擎
Ylucius33 分钟前
动态语言? 静态语言? ------区别何在?java,js,c,c++,python分给是静态or动态语言?
java·c语言·javascript·c++·python·学习
tabzzz35 分钟前
Webpack 概念速通:从入门到掌握构建工具的精髓
前端·webpack
LvManBa43 分钟前
Vue学习记录之六(组件实战及BEM框架了解)
vue.js·学习·rust
200不是二百1 小时前
Vuex详解
前端·javascript·vue.js
滔滔不绝tao1 小时前
自动化测试常用函数
前端·css·html5
LvManBa1 小时前
Vue学习记录之三(ref全家桶)
javascript·vue.js·学习