React——JSX语法【三】

简介: React——JSX语法【三】

前言

JSX(JavaScript XML),React定义的一种类似XML的JS扩展语法。

内容

定义虚拟DOM不可使用引号

const VDOM = (
    <h2 id="id">
        <span>hello JSX</span>
    </h2>
)

标签中混入JS表达式时要用{}

const myId = 'myId'
const myData = 'myData'
const VDOM = (
    <h2 id={myId.toLocaleLowerCase()}>
        <span>{myData.toLocaleLowerCase()}</span>
    </h2>
)

样式类名指定需用className

class为ES6中定义类的关键词,为规避所以React中用className来代替

const myId = 'myId'
const myData = 'myData'
const VDOM = (
    <h2 className="title" id={myId.toLocaleLowerCase()}>
        <span>{myData.toLocaleLowerCase()}</span>
    </h2>
)

内联样式需使用style={{key:value}}来定义

多单词属性需使用小驼峰写法

const VDOM = (
    <h2 className="title" id={myId.toLocaleLowerCase()}>
        <span style={{color:'white',fontSize:'55px'}}>{myData.toLocaleLowerCase()}</span>
    </h2>
)

虚拟DOM只有一个根标签

const myId = 'myId'
const myData = 'myData'
const VDOM = (
    <div>
        <h2 className="title" id={myId.toLocaleLowerCase()}>
            <span style={{color:'white',fontSize:'20px'}}>{myData.toLocaleLowerCase()}</span>
        </h2>
        <input type="text"/>
    </div>
)

JSX标签必须闭合

非成对标签可自闭合<input type="text"/>也可以<input type="text"></input>

const myId = 'myId'
const myData = 'myData'
const VDOM = (
    <div>
        <h2 className="title" id={myId.toLocaleLowerCase()}>
            <span style={{color:'white',fontSize:'20px'}}>{myData.toLocaleLowerCase()}</span>
        </h2>
        <input type="text"/>
    </div>
)

标签首字母

  1. 若小写字母开头,则转为html中同名元素,若html无该同名元素则报错。
  2. 若大写字母开头,则渲染对应组件,若组件没有定义则报错。
const myId = 'myId'
const myData = 'myData'
const VDOM = (
    <div>
        <h2 className="title" id={myId.toLocaleLowerCase()}>
            <span style={{color:'white',fontSize:'20px'}}>{myData.toLocaleLowerCase()}</span>
        </h2>
        <input type="text"/>
        <Good>组件</Good>
    </div>
)

基本规则概括

  1. 遇到 <开头的代码, 以标签的语法解析: html同名标签转换为html同名元素, 其它标签需要特别解析
  2. 遇到以 { 开头的代码,以JS语法解析: 标签中的js表达式必须用{ }包含

练习

<!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小练习</title>
</head>
<style>
    .title {
        background-color: red;
        width: 200px;
        height: 200px;
    }
</style>
<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">
//模拟数据
const data = ['张三', '李四', '王五']
//创建虚拟DOM
const VDOM = (
    <div>
        <h1>好友有列表</h1>
        <ul>
            {
                data.map((item,index)=>{
                    return <li key={index}>{item}</li>
                })
            }
        </ul>
    </div>
)
//渲染
ReactDOM.render(VDOM,document.getElementById('test'))
</script>
</body>
</html

学无止境,谦卑而行.

目录
相关文章
|
3月前
|
前端开发 JavaScript
学习react基础(3)_setState、state、jsx、使用ref的几种形式
本文探讨了React中this.setState和this.state的区别,以及React的核心概念,包括核心库的使用、JSX语法、类与函数组件的区别、事件处理和ref的使用。
91 3
学习react基础(3)_setState、state、jsx、使用ref的几种形式
|
4月前
|
XML JavaScript 前端开发
React Jsx语法入门
【8月更文挑战第13天】React Jsx语法入门
47 4
|
1月前
|
JavaScript 前端开发 容器
React零基础入门02--JSX语法基础
React零基础入门02--JSX语法基础
React零基础入门02--JSX语法基础
|
1月前
|
XML 前端开发 JavaScript
react之了解jsx
react之了解jsx
|
2月前
|
XML 前端开发 JavaScript
React JSX
React 使用 JSX(一种类似 XML 的 JavaScript 语法扩展)来替代传统 JavaScript 编写 UI。JSX 使代码更简洁、执行更快且类型安全。例如,`&lt;h1&gt;Hello, world!&lt;/h1&gt;` 实际上是创建一个 React 元素,通过 `ReactDOM.render()` 渲染到 DOM。注意,JSX 中使用 `className` 替代 HTML 的 `class` 属性。
|
1月前
|
存储 前端开发 JavaScript
react之jsx编译原理
react之jsx编译原理
|
2月前
|
XML 前端开发 JavaScript
React JSX
10月更文挑战第7天
17 2
|
4月前
|
前端开发 JavaScript 开发者
React 的 ES6 语法与 ES5 相比有何不同?
【8月更文挑战第30天】
70 1
|
4月前
|
前端开发 JavaScript
React Server Component 使用问题之添加jsx的组件化能力,如何操作
React Server Component 使用问题之添加jsx的组件化能力,如何操作
|
4月前
|
XML 前端开发 JavaScript
【React新手必看】JSX,让你的代码舞动起来!
【8月更文挑战第24天】JSX(JavaScript XML)是React开发的核心,作为一种JavaScript语法扩展,它支持在代码中使用类似HTML的标签。JSX并非模板语言,在编译过程中转换为纯JavaScript,使React能高效更新DOM并渲染页面。其优势在于直观性、简洁性和灵活性:简化复杂用户界面构建、减少代码量,并支持HTML标签、React组件及JavaScript变量的表达式插入。基本用法涉及定义组件UI,如创建包含标题和段落的简单组件。
96 0