React的组件

React开发者工具调试

在浏览器中下载扩展程序 React Developer Tools,在扩展程序商店或网络上均有下载地址及安装教程

函数式组件

html 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>hello_react></title>
</head>
<body>

    <div id="test"></div>
    
    <script type="text/javascript" scr="./react.develoment.js"></script>
    <script type="text/javascript" scr="./react-dom.development.js"></script>
    <script type="text/javascript" scr="./babel.min.js"></script>
    <script type="text/babel">

    //创建函数式函数
    function Demo(){
        //由于改代码需要babel翻译,开启了ES5的严格模式,this为undefined
        return <h2>函数式组件</h2>
    }
    
    //渲染组件到页面
    ReactDOM.render(<Demo/>,document.getElementById('test'))

    /*
        执行了ReactDOM.render(<Demo/>...之后,发生了什么
        1、React解析组件标签,找到Demo组件
        2、发现组件是使用函数定义的,随后调用函数,将返回的虚拟DOM转化为真实的DOM,随后呈现在                 页面中
     */
    </script>
</body>
</html>

根据JSX的语法规则,标签<Demo /.>需要闭合,而且首字母必须大写,不然会作为html标签从而抛错。

类式组件

html 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>hello_react></title>
</head>
<body>

    <div id="test"></div>
    
    <script type="text/javascript" scr="./react.develoment.js"></script>
    <script type="text/javascript" scr="./react-dom.development.js"></script>
    <script type="text/javascript" scr="./babel.min.js"></script>
    <script type="text/babel">

    //创建类式组件
    class Demo extends React.Component {
        render(){
            //render是放到Demo的原型对象上,供实例使用
            //render的this是Demo的实例对象
            return <h2>类式组件</h2>
        }
    }

    //渲染组件到页面
    ReactDOM.render(<Demo />,document.getElementById('test'))

    /*
        执行了ReactDOM.render(<Demo/>...之后,发生了什么
        1、React解析组件标签,找到Demo组件
        2、发现组件是使用类定义的,随后new出来该类的实例,并通过该实例调用原型上的render方法
        3、将render返回的虚拟DOM转为真实DOM,随后呈现在页面中
     */
    </script>
</body>
</html>
相关推荐
子兮曰1 小时前
Node.js v26.1.0 深度解读:FFI、后量子密码与调试器的进化
前端·后端·node.js
测试员周周1 小时前
【Appium 系列】第06节-页面对象实现 — LoginPage 实战
开发语言·前端·人工智能·python·功能测试·appium·测试用例
西洼工作室2 小时前
前端直传OSS服务端签名(Policy+Signature)/STS临时凭证
前端·文件上传·oss
你很易烊千玺3 小时前
日常练习-数组 字符串常用的场景
前端·javascript·字符串·数组
weixin199701080163 小时前
[特殊字符] RESTful API 接口规范详解:构建高效、可扩展的 Web 服务(附 Python 源码)
前端·python·restful
存在的五月雨4 小时前
Vue3项目一些语法
前端·javascript·react.js
nashane4 小时前
HarmonyOS 6学习:Web组件同层渲染事件处理与智能长截图实现
前端·学习·harmonyos·harmonyos 5
大家的林语冰4 小时前
Node 2026 发布,JS 三大新功能上线,最后一个奇偶版本
前端·javascript·node.js
三*一4 小时前
Mapbox GL JS 自研面要素整形工具开发实录
开发语言·javascript·arcgis·ecmascript