react中jsx的语法规则

发布于:2024-07-03 ⋅ 阅读:(18) ⋅ 点赞:(0)

1.react核心库react.development.js

2.react_dom库,用于支持react操作dom(react-dom.development.js)

3.引入bable,解析jsx语法的库,用于将jsx转换为js(babel.min.js)

上述三个库是写基础react的基本库

下面我将用一个例子来总结jsx语法规则

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>hello_react</title>
    <style>
        .title {
            color: blue;
            background-color: aqua;
        }
    </style>
</head>

<body>

    <!-- 引入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语法的库,用于将jsx转换为js -->
    <script type="text/javascript" src="../js/babel.min.js"></script>
    </script>

    <!-- 准备一个容器用于渲染接收 -->
    <div id="test"></div>



    <script type="text/babel">

        const myId = 'aiXueXi'
        const myData = 'HeLLo,ReaCt'
        // 创建虚拟DOM
        // toLocaleLowerCase()转换成小写字母
        // toUpperCase()转换成大写字母
        const VDOM = (
            <div>
                <h2 className='title' id={myId.toLocaleLowerCase()}>
                    <span>{myData.toLocaleLowerCase()}</span>
                </h2>
                <h3 className='title' id={myId.toUpperCase()}>
                    <span >{myData.toUpperCase()}</span></h3>
                <input type="text" />
                <good>测试</good>

            </div>

        )


        // 渲染虚拟DOM到页面
        ReactDOM.render(VDOM, document.getElementById('test'))

        

    </script>
</body>

</html>

上面一个例子我简单利用react的jsx创建虚拟dom来进行渲染页面

从而总结jsx语法规则如下

  1. 定义虚拟dom的时候不要写引号
  2. 标签中混入js表达式的时候要用花括号
  3. 样式的类名不能用class,要用className
  4. 内联样式,style={{key:value}}的形式去写
  5. 只有一个根标签
  6. 标签首字母分大小写两种情况
  7. 如果首字母小写字母开头,则将改标签转换为html中的同名元素,如果html中没有该标签对应的同名元素就会报错
  8. 如果首字母是大写字母开头,react就会去渲染对应的组件,如果没有该组件就会报错