介绍
- 全称: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"></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>
<!--这里使用了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