对前端的技术进行分层
前端相比较后端而言,由于其发展历史和浏览器的标准不一,导致其看上去简单,但是深入起来又很复杂,在最开始学习的时候,我们往往是了解一下三剑客和vue、react的api就开始上手工作了,但是到后面会发现,每一步就像缺了一根拐杖,而这根拐杖指的就是对前端整个层面的了解。
只有我们建立了对整个层面的了解,才能到我们遇到的问题进行分类,才能在遇到困难的时候,能够分门别类的去解决问题。
前端技术的分层可以类比为计算机科学的“分层抽象”思想,每一层都建立在底层的基础之上,同时又为上层提供更高维度的能力。以下是前端技术的典型分层结构及核心要点:
1. 底层:语言与浏览器引擎层
核心内容
- HTML/CSS/JavaScript
- 原生语言能力(DOM/BOM API、CSSOM、ECMAScript 标准)。
- 浏览器对标准的实现差异(如渲染引擎 Blink/WebKit/Gecko)。
- 浏览器工作原理
- 解析流程(HTML/CSS 解析、构建 DOM/CSSOM 树)。
- 渲染流程(布局、绘制、合成层)。
- JavaScript 执行机制(事件循环、调用栈、微任务/宏任务)。
- 网络协议
- HTTP/HTTPS、WebSocket、TCP/UDP 基础。
- 浏览器缓存策略(强缓存/协商缓存)。
为什么重要?
- 理解底层逻辑:一切上层工具和框架最终都转化为对浏览器 API 的调用。
- 性能优化基础:例如减少重排/重绘需要理解渲染流程。
- 跨端开发根基:浏览器引擎是 WebView、Electron、PWA 的核心。
2. 中间层:工程化与工具链层
核心内容
- 构建工具
- Webpack/Rollup/Vite 的编译流程(AST 转换、Bundle 生成)。
- Babel 的转译原理(插件机制、Polyfill 注入)。
- 模块化与依赖管理
- ES Modules 的静态解析 vs CommonJS 的动态加载。
- npm/yarn/pnpm 的依赖解析算法(嵌套、扁平化、内容寻址)。
- 代码质量工具
- ESLint/Prettier 的 AST 分析与自动修复。
- TypeScript 的类型系统与类型擦除。
- 自动化流程
- CI/CD 的流水线设计(测试、构建、部署)。
- Git Hooks 与协作规范(Commitlint、Husky)。
为什么重要?
- 开发效率保障:工具链决定了项目的可维护性和团队协作效率。
- 性能优化核心:Tree Shaking、Code Splitting 直接影响产物质量。
- 技术选型依据:不同工具适用于不同场景(如 Vite 的按需编译)。
3. 框架层:开发范式与运行时
核心内容
- 框架核心原理
- React 的 Fiber 架构与 Reconciliation 算法。
- Vue 的响应式系统(Proxy/Object.defineProperty)。
- Svelte 的编译时优化(无 Virtual DOM)。
- 状态管理
- Redux 的单向数据流 vs Vuex 的响应式状态。
- Context API、Recoil、Zustand 的设计差异。
- 跨端方案
- React Native/Flutter 的渲染桥接原理。
- Taro/Uniapp 的多端编译逻辑。
为什么重要?
- 开发范式统一:框架决定了代码组织方式(组件化、声明式)。
- 性能天花板:框架的运行时效率直接影响应用性能(如 Vue 3 的 Proxy 优化)。
- 生态依赖:框架生态(如 React 的 Hooks 生态)决定功能扩展能力。
4. 架构层:应用设计与模式
核心内容
- 设计模式
- 组件模式(容器/展示组件、HOC、Render Props)。
- 状态管理策略(全局 Store vs 组件状态)。
- 微前端架构
- 子应用隔离方案(CSS 沙箱、JS 沙箱)。
- 通信机制(CustomEvent、Shared Worker)。
- 服务端渲染(SSR)与静态生成(SSG)
- Hydration 机制与同构渲染。
- 流式渲染(React 18 Suspense)。
- 性能架构
- 按需加载(Dynamic Import)、预加载(Preload/Prefetch)。
- 边缘计算(CDN + Serverless Functions)。
为什么重要?
- 可扩展性:架构设计决定了项目的长期维护成本。
- 技术债务控制:合理的分层和模式避免代码腐化。
- 高可用性保障:例如微前端的独立部署能力提升系统稳定性。
5. 业务层:领域逻辑与工程实践
核心内容
- 业务组件库
- 高内聚、低耦合的组件设计(如表单、表格组件)。
- 主题定制与国际化方案。
- 数据流设计
- API 请求封装(拦截器、错误重试)。
- 前后端数据格式约定(如 GraphQL Schema)。
- 业务监控
- 用户行为埋点(Click/PageView 统计)。
- 异常报警(前端错误日志聚合)。
- 跨团队协作
- 接口 Mock 方案(Swagger + Mock.js)。
- 设计系统(Figma + Storybook 联动)。
为什么重要?
- 交付价值:所有技术最终服务于业务需求。
- 用户体验核心:交互细节、加载策略直接影响用户留存。
- 团队效能:规范的接口和文档降低沟通成本。
分层之间的关系
- 自底向上依赖:上层(如 React)依赖于下层(如 JavaScript 引擎)。
- 自顶向下抽象:业务层通过封装底层细节提升开发效率(如 Ant Design 封装了原生 DOM 操作)。
- 跨层优化:例如性能优化可能同时涉及底层(减少重绘)和架构层(SSR)。
如何系统学习?
- 从底层开始:先掌握 JavaScript 核心和浏览器原理。
- 横向扩展工具链:学习 Webpack、Babel 等工具如何操作底层。
- 纵向深入框架:选择一个框架(如 React),研究其源码和设计思想。
- 实战驱动架构:通过复杂项目(如中后台系统)练习分层设计。
前端技术栈的层次化理解能帮助开发者定位问题(如性能问题属于哪一层)和技术选型(如选择 Vite 还是 Webpack)。掌握分层逻辑后,学习路径会变得更加清晰。
相关文章:
对前端的技术进行分层
前端相比较后端而言,由于其发展历史和浏览器的标准不一,导致其看上去简单,但是深入起来又很复杂,在最开始学习的时候,我们往往是了解一下三剑客和vue、react的api就开始上手工作了,但是到后面会发现&#x…...
【学术投稿-2025年计算机视觉研究进展与应用国际学术会议 (ACVRA 2025)】CSS样式解析:行内、内部与外部样式的区别与优先级分析
简介 2025年计算机视觉研究进展与应用(ACVRA 2025)将于2025年2月28-3月2日在中国广州召开,会议将汇聚世界各地的顶尖学者、研究人员和行业专家,聚焦计算机视觉领域的最新研究动态与应用成就。本次会议将探讨前沿技术,…...
【Linux】【网络】IO多路复用 select、poll、epoll
【Linux】【网络】IO多路复用 select、poll、epoll IO 多路复用 进程或线程同时监控多个文件描述符,查看描述符上是否有事件发生,从而提高资源利用率和系统吞吐量。 1. select int select(int maxfd, fd_set *readfds, fd_set *writefds, fd_set *exc…...
讲解下MySql的外连接查询在SpringBoot中的使用情况
在Spring Boot中使用MySQL的外连接查询时,通常通过JPA、MyBatis或JDBC等持久层框架来实现。外连接查询主要用于从多个表中获取数据,即使某些表中没有匹配的记录。外连接分为左外连接(LEFT JOIN)、右外连接(RIGHT JOIN&…...
OpenGL-基础知识(更新中)
本文基于The Cherno在Youtube上的OpenGL系列视频总结出的笔记,等这个系列视频学习完后,将更加系统详细的学习《计算机图形学编程(使用OpenGL和C 第二版)》这本书。个人认为看cherno的视频上手速度更快,而且他对基本概念…...
逆设计之下,数字纳米光子器件将走向何方?
数字纳米光子器件逆设计是纳米光子学领域中一种创新且极具潜力的设计方法,以下为你详细介绍: 基本概念 纳米光子器件:是指尺寸在纳米量级的光子器件,利用光子(光的粒子)来传输、处理和存储信息。与传统电…...
麒麟信安系统隔核后iperf网络测试影响说明
1、背景介绍 采用麒麟信安系统,在飞腾平台(X86平台类似)上进行了系统核隔离,修改了grub.cfg配置文件中的启动项增加isolcpus2-63 操作,隔核后发现40G网络iperf测试存在影响。 测试命令 taskset -c 16-23 iperf -s -…...
WPF进阶 | WPF 资源管理与本地化:多语言支持与资源复用
WPF进阶 | WPF 资源管理与本地化:多语言支持与资源复用 前言一、WPF 资源管理基础1.1 什么是 WPF 资源1.2 资源的定义与存储位置1.3 资源的引用方式 二、资源字典的深入应用2.1 创建资源字典2.2 在应用程序中合并资源字典2.3 资源字典的层级结构与合并顺序 三、WPF …...
数据结构与算法-动态规划-区间dp(石子合并,环形石子合并,凸多边形的划分,加分二叉树,棋盘分割)
概念 区间动态规划(Interval Dynamic Programming)是动态规划的一个分支,它在处理一些与区间相关的最优解问题上非常有效。以下从基本概念、解题步骤、经典例题、优缺点等方面为你详细介绍: 基本概念:区间 DP 的核心…...
32单片机学习记录4之串口通信
32单片机学习记录4之串口通信 前置 STM32的GPIO口有通用模式,复用模式,模拟模式三种,加上输入输出就是有6中对应的模式。 我学习了通用模式,会使用GPIO口使用一些简单外设,如LED,独立按键,红外…...
开源、免费项目管理工具比较:2025最新整理30款
好用的开源、免费版项目管理系统有:1.Redmine;2. Taiga;3. OpenProject; 4.ProjectLibre; 5.GanttProject; 6.Tuleap; 7.Trac;8. Phabricator; 9.Notion; 10.…...
Android10 音频参数导出合并
A10 设备录音时底噪过大,让音频同事校准了下,然后把校准好的参数需要导出来,集成到项目中,然后出包,导出方式在此记录 设备安装debug系统版本调试好后, adb root adb remount adb shell 进入设备目录 导…...
在 Azure 上部署 DeepSeek 并集成 Open WebUI
DeepSeek 是杭州深度求索人工智能基础技术研究有限公司发布的开源大模型,最近是持续火爆,使得官方服务经常不可用。网上各种本地部署和私有部署的文章已经很多,这里我们提供一个全部基于 Azure 的私有部署方案。 使用 Azure AI Foundry 部署…...
Springboot整合支付宝支付
支付宝支付功能 步骤一:沙箱配置支付宝沙箱配置 步骤二:使用内网穿透步骤三:开始对接SDK配置文件支付 步骤一:沙箱配置 支付宝沙箱配置 需要有支付宝沙箱:提供一个虚拟的支付环境,用于测验调试࿰…...
deepseek+kimi一键生成PPT
1、deepseek生成大纲内容 访问deepseek官方网站:https://www.deepseek.com/ 将你想要编写的PPT内容输入到对话框,点击【蓝色】发送按钮,让deepseek生成内容大纲,并以markdown形式输出。 等待deepseek生成内容完毕后,…...
Druid GetConnectionTimeoutException解决方案之一
> Druid版本:v1.2.18 最近项目中经常出现:com.alibaba.druid.pool.GetConnectionTimeoutException: wait millis 120000, active 0, maxActive 128, creating 0, createErrorCount 2,但是其他平台连接这个数据源正常的 于是做了一个实验复…...
基于ssm的超市订单管理系统
一、系统架构 前端:jsp | web components | jquery | css | ajax 后端:spring | springmvc | mybatis 环境:jdk1.8 | mysql | maven | tomcat 二、代码及数据 三、功能介绍 01. 登录 02. 首页 03. 订单管理 04. 供应…...
AnyPlace:学习机器人操作的泛化目标放置
25年2月来自多伦多大学、Vector Inst、上海交大等机构的论文“AnyPlace: Learning Generalized Object Placement for Robot Manipulation”。 由于目标几何形状和放置的配置多种多样,因此在机器人任务中放置目标本身就具有挑战性。为了解决这个问题,An…...
wps配置deepseek
wps 配置deepseek https://e6jy62bip4.feishu.cn/docx/R09IdpU5HoADyDxcgfQcjpR8nnb...
github不翻墙就可以访问
目录 简介资料准备windows平台设置下载运行git设置firefox设置 ubuntu平台设置下载启动服务设置系统代理git设置firefox设置证书 注意事项 简介 由于github访问不稳定,严重影响了国内软件开发,在网上搜索并验证了一些方法.现在整理出来一个可以正常使用的方法, 在windows和Lin…...
【DeepSeek】在本地计算机上部署DeepSeek-R1大模型实战(完整版)
【作者主页】Francek Chen 【专栏介绍】 ⌈ ⌈ ⌈人工智能与大模型应用 ⌋ ⌋ ⌋ 人工智能(AI)通过算法模拟人类智能,利用机器学习、深度学习等技术驱动医疗、金融等领域的智能化。大模型是千亿参数的深度神经网络(如ChatGPT&…...
基于全志T507的边缘计算机,推动光伏电站向智能运维转型
智能监控与维护 光伏电站通常分布在广阔的地域内,传统的监控方式往往需要大量的人力物力进行现场检查和数据采集。采用全志T507为核心的嵌入式工控机或边缘计算控制器可以实现光伏电站的实时监测,通过连接传感器网络收集电站各个组件的工作状态信息&…...
Swift的方法派发机制
1. 静态派发(Static Dispatch) 静态派发在编译时确定方法的具体实现,调用时直接跳转到该实现。静态派发的优点是性能高,因为不需要运行时查找方法实现。 适用场景: 值类型(Struct 和 Enum)&am…...
用户认证练习实验
一.拓扑 二.sw2配置 三.ip配置 四.dhcp分配IP地址 五.安全区域配置 六.防火墙地址组信息 七.管理员 创建管理员角色 创建管理员 启动tenlnet 八.用户认证配置 认证策略 九.安全策略配置...
Miniforge —— 轻量化的 conda 解决方案
引言 在日常使用中,我们常常使用 Anaconda 或 Miniconda 来管理 Python 环境和包。但由于 Anaconda/Miniconda 属于商业产品,当企业规模超过一定人数时就会涉及付费问题。相比之下,Miniforge 是由社区主导维护的一个完全免费的替代方案&…...
【登录认证】
目录 一. 会话技术1.1 cookie1.2 session1.3 令牌方案 二. JWT令牌三. 过滤器Filter四. 拦截器Interceptor \quad 一. 会话技术 \quad \quad 1.1 cookie \quad \quad 1.2 session \quad \quad 1.3 令牌方案 \quad \quad 二. JWT令牌 \quad \quad 三. 过滤器Filter \quad \quad …...
10bit VS 8bit 视频:色彩深度的较量,谁才是视觉盛宴的王者?
10bit 和 8bit 视频 10bit 视频和 8bit 视频的主要区别在于色彩深度和细节表现能力。10bit 视频具有更高的色彩深度和更丰富的细节表现,能够提供更平滑的色彩过渡和更真实的图像质量,但需要更多的存储空间和带宽。8bit 视频则在存储和传输方面更加高效,适合于对存储空间和带…...
DeepSeek 赋能智慧教育 | 讯方“教学有方”大模型全面接入 DeepSeek!
国产 DeepSeek 大模型以强大的深度学习能力和广泛应用场景迅速火爆全球,其在智能对话、文本创作、语义解析、计算推理、代码生成与补全等多个应用领域,展现出了无与伦比的实力和魅力。2月10日 ,由讯方技术自研的教育行业大模型“教学有方”全…...
代码随想录算法营Day36 | 56. 合并区间,738. 单调递增的数字,968. 监控二叉树
56. 合并区间 每当遇到不重叠的区间就append到结果数组里,遇到重叠的就更新结果数组最后一位的区间的end值。 class Solution:def merge(self, intervals: List[List[int]]) -> List[List[int]]:intervals.sort()res []for start,end in intervals:if len(res…...
Unity中自定义协程的简单实现
在 Unity 中,协程(Coroutine)是一种非常强大的工具,它允许我们在不阻塞主线程的情况下,将代码的执行分成多个步骤,在不同的帧中执行。 Unity中协程实现原理 迭代器与状态机:本质上是基于C#的迭…...
