React

关注公众号 jb51net

关闭
首页 > 网络编程 > JavaScript > javascript类库 > React > react声明式编程和命令式编程

react声明式编程和命令式编程区别小结

作者:光影少年

本文主要介绍了react声明式编程和命令式编程区别小结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

一、核心区别(一句话版本)

二、用一个直观例子对比

🧱 场景:点击按钮切换文本

1️⃣ 命令式写法(传统 DOM 操作)

const btn = document.getElementById('btn');
const text = document.getElementById('text');
btn.addEventListener('click', () => {
  if (text.innerText === 'Hello') {
    text.innerText = 'World';
  } else {
    text.innerText = 'Hello';
  }
});

👉 特点:

2️⃣ 声明式写法(React)

function App() {
  const [text, setText] = React.useState('Hello');
  return (
    <>
      <p>{text}</p>
      <button onClick={() => setText(text === 'Hello' ? 'World' : 'Hello')}>
        切换
      </button>
    </>
  );
}

👉 特点:

三、思维方式差异(重点)

命令式思维(你在“操控”)

1. 找到 DOM
2. 判断当前值
3. 修改 DOM

你要关心:

👉 容易出 bug(尤其复杂页面)

声明式思维(你在“描述”)

UI = f(state) 

你只关心:

👉 剩下的 React 帮你处理

四、为什么 React 一定要声明式?

核心原因就一个:复杂度爆炸时,命令式扛不住

🧠 举个真实场景

一个页面:

❌ 命令式写法

你要:

👉 很快变成“屎山”

✅ React 声明式

if (loading) return <Loading />;
if (error) return <Error />;
return <Table data={data} />;

👉 清晰、可维护

五、底层原理(你做前端建议理解)

React 的声明式依赖:

🔹 Virtual DOM(虚拟 DOM)

流程:

state 变化
   ↓
重新 render(生成新虚拟 DOM)
   ↓
diff 算法对比
   ↓
最小化更新真实 DOM

👉 你不用手动操作 DOM

六、优缺点总结

👍 声明式(React)

优点:

缺点:

👍 命令式

优点:

缺点:

七、一个更高级的理解(建议你掌握)

React 本质是:

状态驱动 UI(State-driven UI)

公式:

UI = f(state) 

这就是声明式的核心。

八、你可以这样记(面试用)

👉 一句话总结:

React 的声明式编程是通过描述 UI 与状态的关系,让框架自动完成 DOM 更新,而不是手动操作 DOM,从而降低复杂度,提高可维护性。

 到此这篇关于react声明式编程和命令式编程区别小结的文章就介绍到这了,更多相关react声明式编程和命令式编程内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文