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>
相关推荐
zhensherlock27 分钟前
Protocol Launcher 系列:Working Copy 文件操作与高级命令详解
javascript·git·typescript·node.js·自动化·github·js
lichenyang4532 小时前
从零到一:用 Taro + React 搭建数据采集小程序
react.js·小程序·taro
神の愛6 小时前
左连接查询数据 left join
java·服务器·前端
小码哥_常8 小时前
解锁Android嵌入式照片选择器,让你的App体验丝滑起飞
前端
郑寿昌9 小时前
IIoT本体迁移的领域扩展机制
服务器·前端·microsoft
深海鱼在掘金9 小时前
Next.js从入门到实战保姆级教程(第十一章):错误处理与加载状态
前端·typescript·next.js
深海鱼在掘金9 小时前
Next.js从入门到实战保姆级教程(第十二章):认证鉴权与中间件
前端·typescript·next.js
energy_DT10 小时前
2026年十五五油气田智能增产装备数字孪生,CIMPro孪大师赋能“流动增产工厂”三维可视化管控
前端
龙猫里的小梅啊10 小时前
CSS(四)CSS文本属性
前端·css
MXN_小南学前端10 小时前
watch详解:与computed 对比以及 Vue2 / Vue3 区别
前端·javascript·vue.js