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

<!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 = (
<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语法规则
- 定义虚拟DOM时,不要写引号。
- 标签中混入JS表达式时要用{}。
- 样式的类名制定不要用class,用className。
- 内联样式要用style={{key:value}}形式去写。
- 虚拟DOM必须只有一个跟标签
- 标签必须闭合。
- 标签首字母:
- 若小写字母开头,则将该标签转成html中同名元素,若html中没有该标签对应的同名元素则报错。
- 若大写字母开头,react就去渲染对应的组件。若组件没有定义,则报错。
注意区分JS语句&JS表达式
- 表达式:一个表达式会产生一个值,可以放在任何一个需要值的地方
下面这些都是表达式:
- a
- a+b
- demo(1)
- arr.map() map方法会return
- function test () {}
- 语句(代码):
下面这些都是语句(代码):
- if(){}
- for(){}
- demo(1)
- switch(){case:''}
jsx练习

<!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>
<script type="text/babel">
const data = [
'angular', 'vue', 'react'
]
const VDOM = (
<div>
<h1>前段js框架列表</h1>
<ul>
{
data.map((item,index)=>{
return <li key={index}>{item}</li>
})
}
</ul>
</div>
)
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>