新手入门:传统 Web 开发与前后端分离开发的区别

一、引言

在互联网应用开发中,Web开发是最常见的软件开发形式之一。随着技术的发展和应用场景的不断扩大,Web应用的开发模式也在不断演进。不同的开发模式在系统架构、开发方式以及前后端职责划分上都有明显的区别。

从整体架构角度来看,Web开发主要可以分为两种模式:传统Web开发前后端分离开发。这两种模式在页面渲染方式、数据交互方式以及系统设计思想上存在较大的差异。理解它们的基本原理和特点,有助于更好地掌握Web应用的开发流程,并在实际项目中选择合适的架构方案。

下面将分别介绍传统Web开发与前后端分离开发的核心思想、优缺点以及它们之间的主要区别。

二、传统Web开发

(一)、传统Web开发的核心思想

前端负责静态页面,后端负责一切。

这里可以细说一下,就相当于,前端只有html页面,后端需要配置页面+资源的路由,需要解析前端页面并动态加载,需要写业务逻辑、数据库、权限控制等等,所有的逻辑都是在服务器后端运行的。

可以这样来说,前端浏览器就是一个显示屏,后端逻辑就是一个cpu,用来控制显示屏的显示逻辑。

(二)、传统web开发的优缺点

优点:

  • 架构简单,不需要前端框架。
  • SEO友好,搜索引擎更容易抓取HTML。
  • 权限控制集中, 传统的Web开发逻辑集中在后端服务器。
  • 开发维护简单,这种简单的架构更容易维护。

缺点:

  • 前后端耦合严重,修改前端页面必须改动后端代码。
  • 页面刷新频繁,用户体验差,每次提交都要刷新页面。
  • 前后端交互能力弱。
  • 不适合多端应用。

三、前后端分离Web开发

(一)、前后端分离Web开发核心思想

前端负责页面、用户交互、页面路由,后端负责业务逻辑等

这种情况下,前端需要负责的就多了,页面的渲染和路由由前端来实现,后端只负责业务和一些控制。

前后端通过JSON来通信,后端不再返回HTML页面。

(二)、前后端分离Web开发的优缺点

优点:

  • 职责清晰,解耦程度高,前后端开发互不影响。
  • 开发效率更高,可以并行开发。
  • 用户体验更好,每次提交不需要再整页刷新。
  • API可以复用。

缺点:

  • 架构更复杂。
  • SEO不友好。
  • 安全和权限设计更复杂。
  • 前端开发成本更高。

四、页面渲染方式

(一)、传统 Web

SSR(Server Side Rendering)

服务器生成完整HTML页面。

流程:

复制代码
浏览器请求
↓
服务器查询数据
↓
服务器生成HTML
↓
返回浏览器
↓
浏览器展示

(二)、前后端分离

CSR(Client Side Rendering)

浏览器负责渲染页面。

流程:

复制代码
浏览器加载前端页面
↓
前端JS请求API
↓
服务器返回JSON
↓
前端渲染页面

五、传统 Web 和前后端分离对比

项目 传统 Web 前后端分离
页面渲染 服务器渲染 SSR 客户端渲染 CSR
HTML 后端返回 前端项目
页面路由 后端 前端
接口 后端 后端
数据格式 HTML JSON
登录 Session JWT / Token
SEO 一般
适合项目 网站 Web应用
相关推荐
河阿里2 分钟前
Spring AOP:企业级实战教学
java·后端·spring
森叶6 分钟前
Electron 实战:用 utilityProcess 开子进程,去端口化承载协议处理,并由主进程拦截渲染请求后统一中转
前端·javascript·electron
Bat U11 分钟前
JavaEE|多线程(五)
java·开发语言·jvm
精益数智工坊11 分钟前
红牌作战是什么?红牌作战的实施步骤与核心要点
大数据·运维·前端·人工智能·精益工程
techdashen17 分钟前
Cloudflare HTML 解析器的十年演化史(一)
前端·html
玉小格25 分钟前
对py作业的一个复盘
开发语言·python
Rust研习社25 分钟前
使用 Tonic 构建高性能异步 gRPC 服务
开发语言·网络·后端·http·rust
ZC跨境爬虫25 分钟前
移动端爬虫工具Fiddler完整配置流程:PC+安卓模拟器全覆盖,零基础一次配置成功
android·前端·爬虫·测试工具·fiddler
captain37628 分钟前
JDBC(Java Data Base Connectivity)
java·开发语言
GISer_Jing30 分钟前
前端视角:B端传统配置化现状与AI冲击趋势
前端·人工智能·ai编程