news 2026/5/4 11:56:17

从后端拼模板到 Vue 响应式:前端界面的三次进化

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
从后端拼模板到 Vue 响应式:前端界面的三次进化

从后端拼模板到 Vue 响应式:一场前端界面的进化史

当开始学习前端开发时,很多人都会遇到一个共同的困惑:
为什么有的项目让后端直接返回 HTML?

为什么后来大家都开始使用 fetch 拉取 JSON?

而现在又流行 Vue 的响应式界面,几乎不再手动操作 DOM?

这些不同的方式看似杂乱,其实背后隐藏着一条非常清晰的技术发展路径。后端渲染 → 前端渲染 → 响应式渲染它们不是独立出现的,而是前端能力逐步增强、分工越来越明确后的必然产物。

1. 🌱 第一阶段:后端拼模板 —— “厨师把菜做好端到你桌上”

让我们从你最初的 Node.js 服务器代码说起。

const http = require("http");// Node.js 内置模块,用于创建 HTTP 服务器或客户端 const url = require("url");// 用于解析 URL const users = [ { id: 1, name: '张三', email: '123@qq.com' }, { id: 2, name: '李四', email: '1232@qq.com'}, { id: 3, name: '王五', email: '121@qq.com' } ]; // 将 `users` 数组转换为 HTML 表格字符串 function generateUserHTML(users){ const userRows = users.map(user => ` <tr> <td>${user.id}</td> <td>${user.name}</td> <td>${user.email}</td> </tr> `).join(''); return ` <html> <body> <h1>Users</h1> <table> <tbody>${userRows}</tbody> </table> </body> </html> `; } // 创建一个 HTTP 服务器,传入请求处理函数 const server = http.createServer((req, res) => { if(req.url === '/' || req.url === '/users'){ res.setHeader('Content-Type', 'text/html;charset=utf-8'); res.end(generateUserHTML(users)); } }); // 服务器监听本地 1314 端口。 server.listen(1314);

访问1314端口,得到的结果:

这段代码非常典型,体现了早期 Web 的模式:

  • 用户访问/users
  • 后端读取数据
  • 后端拼出 HTML
  • 后端把完整页面返回给浏览器

你可以把它理解成:

用户去餐馆点菜 → 厨房(后端)把菜做好 → 端到你桌上(浏览器)

整个过程中,浏览器不参与任何加工,它只是“展示已经做好的菜”。


🔍 后端拼模板的特点

特点说明
后端掌控视图HTML 是后端生成的
数据和页面耦合在一起改数据就要改 HTML 结构
刷新页面获取新数据无法局部更新
用户体验一般交互不够流畅

这种方式在早期 Web 非常普遍,就是典型的 MVC:

  • M(Model):数据
  • V(View):HTML 模板
  • C(Controller):拼 HTML,返回给浏览器

“后端拼模板”就像饭店里:

  • 厨师(后端)把所有食材(数据)做成菜(HTML)
  • 顾客(浏览器)只能被动接受

这当然能吃饱,但吃得不灵活。

为了吃一个小菜,还要大厨重新做一桌菜!

这就导致页面每个小变化都得刷新整个页面。


2. 🌿 第二阶段:前后端分离 —— “厨师只给食材,顾客自己配菜”

随着前端能力提升,人们发现:

让后端拼页面太麻烦了。

于是产生了前后端分离


🔸 后端从“做菜”变成“送食材”(只返回 JSON)

{ "users": [ { "id": 1, "name": "张三", "email": "123@qq.com" }, { "id": 2, "name": "李四", "email": "1232@qq.com" }, { "id": 3, "name": "王五", "email": "121@qq.com" } ] }

JSON Server 会把它变成一个 API:

GET http://localhost:3000/users

访问该端口得到:

访问时返回纯数据,而不再返回 HTML。


🔸 前端浏览器接管“配菜”(JS 渲染 DOM)

<script> fetch('http://localhost:3000/users')// 使用浏览器内置的 `fetch`() API 发起 HTTP 请求。 .then(res => res.json())// 解析响应为 JSON // 渲染数据到页面 .then(data => { const tbody = document.querySelector('tbody'); tbody.innerHTML = data.map(user => ` <tr> <td>${user.id}</td> <td>${user.name}</td> <td>${user.email}</td> </tr> `).join(''); }); </script>

浏览器自己:

  1. 发送 fetch 请求
  2. 拿到 JSON
  3. 用 JS 拼 HTML
  4. 填入页面


这就好比:

  • 后端:不做菜,只把干净的食材准备好(纯 JSON)
  • 前端:自己按照 UI 要求把菜炒出来(DOM 操作)
  • 双方分工明确,互不干扰

这就是现代 Web 最主流的模式 ——前后端分离


🚧 但问题来了:DOM 编程太痛苦了

你看这段代码:

tbody.innerHTML = data.map(user => ` <tr>...</tr> `).join('');

是不是很像在手工组装乐高积木?

DOM 操作会遇到几个痛点:

  • 代码又臭又长
  • 更新数据要重新操作 DOM
  • 状态多了之后难以维护
  • 页面结构和业务逻辑混在一起

前端工程师开始苦恼:

有没有一种方式,让页面自动根据数据变化?

于是,Vue、React、Angular 出现了。


3. 🌳 第三阶段:Vue 响应式数据驱动 —— “只要食材变化,餐盘自动变化”

Vue 的核心理念:

ref 响应式数据,将数据包装成响应式对象
界面由 {{}} v-for 进行数据驱动
专注于业务,数据的变化而不是 DOM

这是前端的终极模式 ——响应式渲染


🔥 Vue 的思想

Vue 做了三件事:

  1. 把变量变成“会被追踪的数据”(ref / reactive)
  2. 把 HTML 变成“模板”(用 {{ }}、v-for)
  3. 让数据变化自动修改 DOM

你只需要像写伪代码一样描述业务:

<script setup> import { ref, onMounted // 挂载之后 } from 'vue' const users = ref([]); // 在挂载后获取数据 onMounted(() =>{ fetch('http://localhost:3000/users') .then(res => res.json()) .then(data => { users.value = data; }) }) </script>

而页面模板:

<tr v-for="u in users" :key="u.id"> <td>{{ u.id }}</td> <td>{{ u.name }}</td> <td>{{ u.email }}</td> </tr>

得到的结果为:

你不再需要:

  • querySelector
  • innerHTML
  • DOM 操作

Vue 会自己完成这些工作。


如果 传统 DOM:

你要把所有食材手动摆到盘子里。

那么Vue:

你只需要放食材到盘子里(修改数据),
餐盘的摆盘会自动变化(界面自动更新)。

比如你修改了数组:

users.value.push({ id: 4, name: "新用户", email: "xxx@qq.com" });

页面会自动新增一行。

你删除:

users.value.splice(1, 1);

页面自动少一行。

你完全不用动 DOM。


4. 🌲 三个阶段的对比

阶段数据从哪里来?谁渲染界面?技术特征
1. 后端渲染(server.js)后端后端拼 HTML模板字符串、MVC
2. 前端渲染(index.html + db.json)API / JSON前端 JS DOMFetch、innerHTML
3. Vue 响应式渲染API / JSONVue 自动渲染ref、{{}}、v-for

本质是渲染责任的迁移:

后端渲染 → 前端手动渲染 → 前端自动渲染

最终目标只有一个:

让开发者把时间花在业务逻辑,而不是重复性 DOM 操作上。


5. 🍁 为什么现代开发必须用前后端分离 + Vue?

最后,让我们用一句最通俗的话总结:

后端拼页面像“饭店厨师包办一切”,效率低。
前端手动拼 DOM 像“自己做饭”,累到爆。
Vue 像“智能厨房”,你只需要准备食材(数据)。

Vue 的三大优势

1)极大减少开发成本

业务逻辑变简单:

users.value = newUsers;

就够了,UI 自动更新。

2)更适合大型项目
  • 组件化
  • 模块化
  • 状态集中管理
  • 可维护性高
3)用户体验更好
  • 页面不刷新
  • 更新局部
  • 响应迅速

6. 🌏 文章总结:从“厨房”看前端的进化历史

最终,我们回到开头的类比:

阶段类比
第一阶段:后端拼模板厨房(后端)做好所有菜,直接端给你
第二阶段:前端渲染厨房只提供食材,你自己炒
第三阶段:Vue 响应式智能厨房:只要食材变,菜自动做好

前端技术每一次进化,都围绕同一个核心目标:

让开发者更轻松,让用户体验更好。

而你上传的代码正好构成了一个完美的演示链路:
从最原始的后端拼模板,到 fetch DOM 渲染,再到 Vue 响应式渲染。

理解了这三步,你就理解了整个现代前端技术的发展脉络。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/2 12:14:53

高效B站视频下载工具:智能批量下载解决方案

在当今数字内容丰富的时代&#xff0c;B站作为国内领先的视频分享平台&#xff0c;汇聚了大量优质内容。然而&#xff0c;网络波动、内容下架风险等因素常常影响用户的观看体验。专业的B站视频下载工具应运而生&#xff0c;提供高效、智能的批量下载能力&#xff0c;让用户可以…

作者头像 李华
网站建设 2026/5/1 7:21:42

AWR1843毫米波雷达数据可视化:三分钟搞定实时环境感知

AWR1843毫米波雷达数据可视化&#xff1a;三分钟搞定实时环境感知 【免费下载链接】AWR1843-Read-Data-Python-MMWAVE-SDK-3- Python program to read and plot the data in real time from the AWR1843 mmWave radar board (MMWAVE SDK 3) 项目地址: https://gitcode.com/gh…

作者头像 李华
网站建设 2026/4/27 21:16:34

BG3Mod管理器终极指南:从入门到精通完整教程

BG3Mod管理器终极指南&#xff1a;从入门到精通完整教程 【免费下载链接】BG3ModManager A mod manager for Baldurs Gate 3. 项目地址: https://gitcode.com/gh_mirrors/bg/BG3ModManager BG3Mod管理器是《博德之门3》玩家必备的专业模组管理工具&#xff0c;能够帮助您…

作者头像 李华
网站建设 2026/5/1 8:55:22

Monitorian:Windows多显示器亮度调节的专业解决方案

Monitorian&#xff1a;Windows多显示器亮度调节的专业解决方案 【免费下载链接】Monitorian A Windows desktop tool to adjust the brightness of multiple monitors with ease 项目地址: https://gitcode.com/gh_mirrors/mo/Monitorian 项目核心价值 Monitorian是一…

作者头像 李华
网站建设 2026/5/1 6:11:39

30、Knoppix系统的安装、更新、软件安装及常用命令指南

Knoppix系统的安装、更新、软件安装及常用命令指南 Knoppix系统安装步骤 重复输入密码 :再次输入密码并按回车键,此时会出现“Creating Knoppix Configuration Step (5/7)”屏幕。 输入root密码 :输入root(管理员)密码,按回车键,然后像之前输入登录账户密码一样再次…

作者头像 李华
网站建设 2026/5/3 23:12:25

JVM垃圾回收算法?

JVM 垃圾回收&#xff08;GC&#xff09;算法的核心目标是精准识别堆中无用对象并回收其内存&#xff0c;同时兼顾回收效率、内存利用率和停顿时间。算法的演变围绕「标记 - 清理 - 整理」的核心思路展开&#xff0c;分为4 种基础算法、1 种组合策略&#xff08;分代收集&#…

作者头像 李华