React快速入门之渲染

【前置知识】什么是DOM?

  • 浏览器只会绘制(渲染)HTML或XML文档
<!DOCTYPE html>
<html>
<head>
    <title>我的网页</title>
</head>
<body>
    <header>
        <h1>欢迎来到我的网页</h1>
    </header>
    <main>
        <section>
            <p>这是一段内容。</p>
        </section>
    </main>
    <footer>
        <p>版权所有 &copy; 2022</p>
    </footer>
</body>
</html>
  • 浏览器会将HTML或XML文档解析为DOM🌲供JavaScript修改
    在这里插入图片描述

  • 浏览器会监听DOM🌲的变化,并在DOM树被修改后重新绘制(渲染)对应的部分。

React的初始渲染

  • React将元素渲染到同一个HTML文档中,其中id为root的div是React应用元素挂载点!
<!DOCTYPE html>
<html lang="en">
  ......
  <body>
  	......
    <div id="root"></div>
  </body>
</html>

  • 获取root标签,并创建为React应用的根DOM节点
** 创建根DOM节点
const root = ReactDOM.createRoot(document.getElementById('root'));

** 让浏览器从root根DOM节点开始渲染
root.render(
  <React.StrictMode> // 严格模式
    <App /> // 根组件
  </React.StrictMode>
);

React修改DOM后渲染

<h1>{time}</h1>标签每秒钟都会重新渲染,但是<input />不会重新渲染,可以正常输入。因为React只会重新渲染由javascript修改的DOM,而没有修改的DOM不会被修改!

export default function Clock({ time }) {
  return (
    <>
      <h1>{time}</h1>
      <input />
    </>
  );
}
  • 5
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值