• React——虚拟DOM创建的两种方式【二】


    前言

    如题,虚拟DOM创建的两种方式jsjsx

    内容

    使用jsx创建虚拟DOM

    <!doctype html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <meta name="viewport"
              content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0">
        <meta http-equiv="X-UA-Compatible" content="ie=edge">
        <title>使用jsx创建虚拟DOM</title>
    </head>
    <body>
    <!--创建"容器"-->
    <div id="test">
    
    </div>
    <!--引入react核心库-->
    <script type="text/javascript" src="../js/react.development.js"></script>
    <!--引入react-dom,用于支持react操作DOM-->
    <script type="text/javascript" src="../js/react-dom.development.js"></script>
    <!--引入babel,用于将jsx转js-->
    <script type="text/javascript" src="../js/babel.min.js"></script>
    <script type="text/babel">/*一定要以text/babel来声明*/
    //1. 创建虚拟DOM
    const VDOM = <h1>Hello, React</h1>/*此处一定不要写引号*/
    //2. 渲染虚拟DOM到页面
    ReactDOM.render(VDOM,document.getElementById('test'))
    </script>
    </body>
    </html>
    

    使用js创建虚拟DOM

    <!doctype html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <meta name="viewport"
              content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0">
        <meta http-equiv="X-UA-Compatible" content="ie=edge">
        <title>使用js创建虚拟DOM</title>
    </head>
    <body>
    <!--创建"容器"-->
    <div id="test">
    
    </div>
    <!--引入react核心库-->
    <script type="text/javascript" src="../js/react.development.js"></script>
    <!--引入react-dom,用于支持react操作DOM-->
    <script type="text/javascript" src="../js/react-dom.development.js"></script>
    <script type="text/javascript">/*此处以js来创建一定要以text/javascript来声明*/
    //1. 创建虚拟DOM
    const VDOM = React.createElement('h1',{id:'title'},'Hello React')
    //2. 渲染虚拟DOM到页面
    ReactDOM.render(VDOM,document.getElementById('test'))
    </script>
    </body>
    </html>
    

    虚拟DOM和真实DOM

    <!DOCTYPE html>
    
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>3_虚拟DOM与真实DOM</title>
    </head>
    <body>
    <!-- 准备好一个“容器” -->
    <div id="test"></div>
    <div id="demo"></div>
    
    <!-- 引入react核心库 -->
    <script type="text/javascript" src="../js/react.development.js"></script>
    <!-- 引入react-dom,用于支持react操作DOM -->
    <script type="text/javascript" src="../js/react-dom.development.js"></script>
    <!-- 引入babel,用于将jsx转为js -->
    <script type="text/javascript" src="../js/babel.min.js"></script>
    
    <script type="text/babel" > /* 此处一定要写babel */
    //1.创建虚拟DOM
    const VDOM = (  /* 此处一定不要写引号,因为不是字符串 */
        <h1 id="title">
            <span>Hello,React</span>
        </h1>
    )
    //2.渲染虚拟DOM到页面
    ReactDOM.render(VDOM,document.getElementById('test'))
    
    // 虚拟DOM
    // console.log(typeof VDOM);
    // console.log(VDOM instanceof Object);
    // 真实DOM
    const TDOM = document.getElementById('demo')
    console.log('虚拟DOM',VDOM);
    console.log('真实DOM',TDOM);
    debugger;
    
    /*
            关于虚拟DOM:
                1.本质是Object类型的对象(一般对象)
                2.虚拟DOM比较“轻”,真实DOM比较“重”,因为虚拟DOM是React内部在用,无需真实DOM上那么多的属性。
                3.虚拟DOM最终会被React转化为真实DOM,呈现在页面上。
     */
    </script>
    </body>
    </html>
    
    学无止境,谦卑而行.
  • 相关阅读:
    20151216JqueryUI---dialog代码备份
    20151215jqueryUI--dialog代码备份
    20151215jquery学习笔记--jqueryUI --dialog(对话框)
    20151214 jquery插件代码备份
    20151213Jquery学习笔记--插件
    javaweb常用工具类及配置文件备份
    Javaweb常用工具类及配置文件备份
    20151212Jquery 工具函数代码备份
    20151212jquery学习笔记--工具函数
    CF976E Well played!
  • 原文地址:https://www.cnblogs.com/wangyang0210/p/14391586.html
Copyright © 2020-2023  润新知