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>
相关推荐
佛山个人技术开发6 分钟前
个人建站接单|汽车汽配行业宽屏自适应官网模板 工厂企业定制建站源码
前端·css·前端框架·html·汽车·php
光影少年17 分钟前
react的Context 和 Redux 区别?
前端·javascript·react.js·前端框架
前端 贾公子24 分钟前
uni-app工程化实战:基于vue-i18n和i18n-ally的国际化方案 (上)
前端·javascript·vue.js
喵个咪39 分钟前
基于 Flutter 的 Headless CMS 全平台前端架构:技术解析与二次开发导引
前端·flutter·cms
甜味弥漫1 小时前
React 快速入门:从 JSX 到列表渲染
react.js·前端框架·node.js
vim怎么退出1 小时前
Dive into React——Diff 算法
前端·react.js·源码阅读
半个落月1 小时前
面试必问的 JS 原型链,我用 16 个示例给你彻底讲明白
javascript
拾年2751 小时前
别调 BERT 了:我用 Prompt 做了套 NLP 系统,20 分钟搞定
前端·人工智能
丷丩1 小时前
12. 渲染:MapLibre GL JS 集成与多源瓦片联动
javascript·矢量瓦片·maplibre gl js·地图服务器
半个落月1 小时前
别再死记变量提升了——从 V8 编译过程真正理解 JS 执行机制
前端