1. React 是什么?
比喻理解
-
React = 汽车制造厂的设计图纸和核心零件
-
它告诉你如何造一辆车(如何构建用户界面)
-
但它不提供汽油 (数据API)也不提供加油站(数据库)
-
技术定义
javascript
// React 本质上是一个 JavaScript 库,用来构建用户界面
// 它只关心一件事:如何把数据变成好看的界面
const 用户界面 = React.组件({
数据: { 用户名: "张三", 年龄: 25 },
逻辑: function() { /* 处理点击等交互 */ }
});
// 输出:<div>你好,张三!你25岁了。</div>
React 的核心价值
-
组件化:把界面拆成独立、可复用的部分
-
声明式:告诉它"界面应该长什么样",而不是"怎么一步一步画出来"
-
响应式:数据变了,界面自动更新
React vs Java API(帮助文档)的关系
javascript
用户点击页面
↓
React组件向Java API请求数据(像汽车去加油)
↓
Java API返回数据(给汽油)
↓
React用数据渲染界面(用汽油驱动汽车)
React vs Supabase(数据库)的关系
javascript
Supabase(油库)
↓ 通过管道(API)
Java/Node.js API(加油站)
↓ 加油枪(HTTP请求)
React汽车(用户界面)
构建一个完整的 Web 应用
javascript
一家汽车运输公司需要:
1. 加油站(Supabase/MySQL数据库)← 存储货物信息
2. 调度中心(Java API后端)← 决定货物怎么运输
3. 卡车(React前端)← 把货物展示给客户看
4. 卡车制造厂(React框架本身)← 提供卡车的制造标准
没有加油站:卡车没油跑不动(没数据)
没有调度中心:卡车不知道去哪(没业务逻辑)
没有卡车:客户看不到货物(没界面)
没有制造厂:没地方造卡车(没开发工具)


Next.js 13+ 是 React 框架的"大版本升级",不是一个新语言,而是一套全新的开发工具和功能集合。
学习React就是学习如何把后端数据"包装"成用户友好的界面给前端用户看。