005.jsx语法规则

介绍

  1. 全称:JavaScript XML
  2. react定义的一种类似于XML的JS扩展语法:JS+XML
  3. 本质是React.createElement(component,props,…children)方法的语法糖
  4. 作用是用来创建简化虚拟DOM
  5. 标签名任意

举个?:

image.png

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        .title{
            background-color: #ddd;
            width: 200px;
        }
    </style>
</head>
<body>
    <div id="test"></div>

    <!-- 引入依赖 ,引入的时候,必须就按照这个步骤-->
    <script type="text/javascript" src="../js/react.development.js"></script>
    <script type="text/javascript" src="../js/react-dom.development.js"></script>
    <script type="text/javascript" src="../js/babel.min.js"></script>

    <script type="text/babel">
        const id = 'AtHome'
        const name = 'JerryNeva'
        // const VDOM = (
        //     <h2 id="span">
        //         <span>hello react</span>    
        //     </h2>
        // )
        const VDOM = (
            <div>
                <h2 className="title" id={id.toLocaleLowerCase() || "span"}>
                    <span style={{color:'white',fontSize:'20px'}}>{name.toLocaleLowerCase() || "hello react"}</span>    
                </h2>
                <h2 className="title" id={id.toLocaleLowerCase() || "span"}>
                    <span style={{color:'white',fontSize:'20px'}}>{name.toLocaleLowerCase() || "hello react"}</span>    
                </h2>
            </div>
        )

        ReactDOM.render(VDOM,document.getElementById('test'))
    </script>
</body>
</html>
复制代码

jsx语法规则

  1. 定义虚拟DOM时,不要写引号。
  2. 标签中混入JS表达式时要用{}。
  3. 样式的类名制定不要用class,用className。
  4. 内联样式要用style={{key:value}}形式去写。
  5. 虚拟DOM必须只有一个跟标签
  6. 标签必须闭合。
  7. 标签首字母:
    • 若小写字母开头,则将该标签转成html中同名元素,若html中没有该标签对应的同名元素则报错。
    • 若大写字母开头,react就去渲染对应的组件。若组件没有定义,则报错。

注意区分JS语句&JS表达式

  1. 表达式:一个表达式会产生一个值,可以放在任何一个需要值的地方
    下面这些都是表达式:

    • a
    • a+b
    • demo(1)
    • arr.map() map方法会return
    • function test () {}
  2. 语句(代码):
    下面这些都是语句(代码):

    • if(){}
    • for(){}
    • demo(1)
    • switch(){case:”}

jsx练习

image.png

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<body>
    <!-- 准备好容器 -->
    <div id="test"></div>
    <div id="demo"></div>
    <!-- 引入依赖 ,引入的时候,必须就按照这个步骤-->
    <script type="text/javascript" src="../js/react.development.js"></script>
    <script type="text/javascript" src="../js/react-dom.development.js"></script>
    <script type="text/javascript" src="../js/babel.min.js"></script>
    
    <!--这里使用了babel用来解析jsx语法-->
    <script type="text/babel">
        // 模拟一些数据
        const data = [
            'angular', 'vue', 'react'
        ]
        // 1.创建虚拟DOM
        const VDOM = (
            <div>
                <h1>前段js框架列表</h1>
                <ul>
                    {
                        data.map((item,index)=>{
                            return <li key={index}>{item}</li>
                        })
                    }    
                </ul>
            </div>
        )
        // 2.渲染
        ReactDOM.render(VDOM,document.getElementById("test"));

        const TDOM = document.getElementById('demo')
        console.log(typeof VDOM)
        console.log('虚拟DOM',VDOM)
        console.log('真实DOM',TDOM)
    </script>
</body>
</html>
复制代码
© 版权声明
THE END
喜欢就支持一下吧
点赞0 分享