【React】React 哲学

1. 声明式(Declarative)

React 鼓励开发者 描述 UI 应该是什么样子,而不是逐步操作 DOM。

jsx 复制代码
// 声明式
function Greeting({ name }) {
  return <h1>Hello, {name}</h1>;
}
  • 不用手动操作 DOM(document.getElementById / innerHTML)
  • React 根据状态自动更新 UI

面试回答示例:

"React 倡导声明式编程,我们只关心状态是什么样子,React 会负责把状态映射成界面,简化了 DOM 操作和状态管理的复杂度。"


2. 组件化(Component-Based)

  • UI 被拆分成可复用、独立的组件
  • 每个组件管理自己的状态和逻辑
  • 便于维护和组合
jsx 复制代码
function Button({ onClick, children }) {
  return <button onClick={onClick}>{children}</button>;
}

面试回答示例:

"React 通过组件化思想,把页面拆成小的、可复用的块,每个组件只关注自己的状态和 UI,提高了代码的可维护性和复用性。"


3. 单向数据流(One-way Data Flow)

  • 数据从父组件流向子组件
  • 状态集中、可控
  • 简化调试和逻辑理解
jsx 复制代码
function Parent() {
  const [count, setCount] = useState(0);
  return <Child count={count} />;
}

面试回答示例:

"React 数据是单向流动的,父组件通过 props 传递数据给子组件,这样数据的变化是可追踪的,状态管理更清晰。"


4. UI = f(state)(函数式思想)

  • React 的 UI 可以看作是 状态到界面的函数
  • 输入(state/props)确定输出(UI),减少副作用
jsx 复制代码
function TodoList({ todos }) {
  return (
    <ul>
      {todos.map(todo => <li key={todo.id}>{todo.text}</li>)}
    </ul>
  );
}

面试回答示例:

"在 React 中,界面完全由状态驱动,我们可以把 UI 看作是状态的函数,状态变化就会自动映射到 UI 上。"


5. 虚拟 DOM(Virtual DOM)

  • React 使用虚拟 DOM 对比状态变化前后的差异,只更新必要的部分
  • 提高渲染效率

面试回答示例:

"React 使用虚拟 DOM diff 算法,避免不必要的 DOM 操作,提升性能,同时开发者不用手动优化 DOM。"


6. hooks

Hooks 之所以叫钩子,是因为它提供了一种方式,让函数组件可以'钩入' React 的状态管理和生命周期等机制。

比如 useState 钩住了 state,useEffect 钩住了副作用逻辑。它的本质就是一个连接点,让函数组件不再只是一个纯函数,而能复用逻辑、维护状态,从而拥有类组件的能力甚至更灵活。

✅ 总结

  1. 声明式:只描述想要的 UI
  2. 组件化:UI 拆分成独立、复用的组件
  3. 单向数据流:父传子,状态可控
  4. 函数式 UI:UI = f(state)
  5. 虚拟 DOM:高效更新 DOM
相关推荐
码丁_11729 分钟前
为什么前端需要做优化?
前端
Mr Xu_41 分钟前
告别硬编码:前端项目中配置驱动的实战优化指南
前端·javascript·数据结构
Byron07071 小时前
从 0 到 1 搭建 Vue 前端工程化体系:提效、提质、降本实战落地
前端·javascript·vue.js
哆啦code梦1 小时前
前端存储三剑客:localStorage、sessionStorage与Cookie解析
前端·前端存储
徐小夕@趣谈前端1 小时前
Web文档的“Office时刻“:jitword共建版2.0发布!让浏览器变成本地生产力
前端·数据结构·vue.js·算法·开源·编辑器·es6
Data_Journal2 小时前
如何使用 Python 解析 JSON 数据
大数据·开发语言·前端·数据库·人工智能·php
德育处主任Pro2 小时前
纯前端网格路径规划:PathFinding.js的使用方法
开发语言·前端·javascript
墨笔.丹青2 小时前
基于QtQuick开发界面设计出简易的HarmonyUI界面----下
开发语言·前端·javascript
董世昌412 小时前
深度解析浅拷贝与深拷贝:底层逻辑、实现方式及实战避坑
前端·javascript·vue.js
扶苏10022 小时前
vue使用event.dataTransfer实现A容器数据拖拽复制到到B容器
前端·vue.js·chrome