React JSX基础语法教程示例

 更新时间:2023年09月15日 14:20:15   作者:羽旋杯水  
这篇文章主要为大家介绍了React JSX基础语法教程示例,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

1、什么是 JSX

JSX 是 JavaScript 的一种语法扩展。可以组装 UI 界面,同时可以和 JavaScript 语法配合使用。

2、为什么使用 JSX

  • 使用熟悉的语法定义 HTML 元素,提供更加语义化的标签,使用 JSX 编写模板更简单快速
  • 更加直观:JSX 让组件更加简单、明了、直观
  • 抽象了 React 元素的创建过程,使得编写组件变得更加简单

举例说明如下:

// react17版本之前
const children1 = React.createElement("li", null, "第一个组件内容!");
const children2 = React.createElement("li", null, "第二个组件内容!");
const root = React.createElement(
  "ul",
  { className: "list" },
  children1,
  children2
);
// react17版本之后
import { jsx as _jsx } from "react/jsx-runtime";
import { jsxs as _jsxs } from "react/jsx-runtime";
const root = _jsxs("ul", {
  className: "list",
  children: [
    _jsx("li", {
      children: "Hello",
    }),
    _jsx("li", {
      children: "World",
    }),
  ],
});

JSX 等价如下:

const root = (
  <ul className="list">
    <li>Hello</li>
    <li>World</li>
  </ul>
);

显然 JSX 写法更便于页面的编写与维护,且简单、直观。

3、JSX 书写规范

  • JSX 的最外层只能有一个根元素,可以使用 div 、span 等标签
  • 正常情况下,我可以在最外层包裹一个小括号(),方便我们更好的格式化代码
  • JSX 中的标签可以是单标签,也可以是双标签;注意:如果是单标签,必须以/>结尾
  • 在使用变量时,我们可以将其放在一个大括号中,大括号内可以放置任何有效的 JavaScript 表达式

代码示例如下:

const root = (
  <div className="list">
    <div>第一个组件内容!</div>
    <img src="xxx.jpg" />
    {1 === 1 && <div>第二个组件内容!</div>}
  </div>
);

4、JSX 注释

通常有以下三种注释

<ul className="list">
  {/* 1、单行注释 */}
  <li>第一个组件内容!</li> // 2、行尾注释
  <li>第二个组件内容!</li>
  {/*
        3、多行注释
        1
        2
        3
        */}
</ul>

5、JSX 嵌入变量

变量在 JSX 使用,需要用大括号 { } 包裹;注意:使用的变量需要提前定义。如下。

const MyComponent = () => {
  const text = "Hello World!";
  return <div>{text}</div>;
};
export default MyComponent;

6、JSX 嵌入表达式

  • 运算符表达式
  • 三元表达式
  • 函数调用
const MyComponent = () => {
  const isFinish = true;
  const calc = () => {
    const a = 1;
    const b = 2;
    return a + b;
  };
  return (
    <div>
      {/*1.运算符表达式*/}
      <span>2 + 3 的和为:{2 + 3}</span>
      {/*2.三元表达式*/}
      <span>家庭作业是否完成:{isFinish ? "是" : "否"}</span>
      {/*3.进行函数调用*/}
      <span>{calc()}</span>
    </div>
  );
};
export default MyComponent;

7、JSX 绑定属性

注意:在给元素绑定 style 时,外层的大括号是表示可传入变量或者表达式。而内部的大括号是一个对象,它里面是键值对,表示元素的样式属性及属性值。另外,当属性是由多个单词组成的时候,需要用驼峰命名法来表示,例如:fontSize

const MyComponent = () => {
  const title = "我是标题的全部内容!";
  const url = "https://www.baidu.com";
  const className = "span";
  return (
    <div>
      {/* 1、绑定普通属性 */}
      <h2 title={title}>我是标题...</h2>
      <a href={url}>百度一下</a>
      {/* 2.绑定class */}
      <span className={className}>我是span标签</span>
      <span className={["tag", "span"].join(" ")}>我是span标签2</span>
      {/* 3.绑定style */}
      <span style={{ color: "red", fontSize: 16 }}>我的字体颜色是红色</span>
    </div>
  );
};
export default MyComponent;

8、JSX 绑定事件

可以看出 React 元素的事件处理和 DOM 元素的很相似,但存在一些语法上的差异:

  • React 的事件采用驼峰式命名,而不是纯小写的方式
  • 使用 JSX 语法时,需要传入一个函数作为事件处理函数,而不是一个字符串
  • 使用函数时不能加括号,不然会直接执行
  • 如果函数过于简单,可在 JSX 中直接编写函数内容
const MyComponent = () => {
  const onClick = () => {
    window.alert("您点击了按钮1");
  };
  return (
    <div>
      <button onClick={onClick}>按钮1</button>
      <button
        onClick={() => {
          window.alert("您点击了按钮2");
        }}
      >
        按钮2
      </button>
    </div>
  );
};
export default MyComponent;

9、JSX 条件渲染

常见的条件渲染的方式有以下三种:

  • 方式一:条件判断语句,适合逻辑较多的情况
  • 方式二:三元运算符,适合逻辑比较简单
  • 方式三:与运算符&&,如果条件成立,渲染&&后面的组件;如果条件不成立,则都不渲染
const MyComponent = () => {
  const renderTitle = (key) => {
    if (key > 1) {
      return <span>我是标题1</span>;
    }
    return <span>我是标题2</span>;
  };
  return (
    <div>
      {renderTitle(2)}
      {2 > 1 ? <span>我会显示出来</span> : <span>我会隐藏</span>}
      {2 > 1 && <span>我会显示出来</span>}
    </div>
  );
};
export default MyComponent;

10、JSX 列表渲染

我们通常使用 Javascript 的 map 函数来处理 JSX 数组列表循环渲染;如下

const MyComponent = () => {
  const array = ["1", "2", "3", "4"];
  return (
    <ul>
      {array.map((i) => (
        <li key={i}>{i}</li>
      ))}
    </ul>
  );
};
export default MyComponent;

注意:在渲染是,我们需要给渲染项添加一个 key,不然会报错:warning: Each child in a list should have a unique "key" prop.

key 和 React 中的 diff 算法密切相关。

以上就是React JSX基础语法教程示例的详细内容,更多关于React JSX基础语法的资料请关注脚本之家其它相关文章!

相关文章

  • React事件机制源码解析

    React事件机制源码解析

    这篇文章主要介绍了React事件机制源码解析的相关资料,帮助大家更好的理解和学习使用React框架,感兴趣的朋友可以了解下
    2021-04-04
  • React实现卡片拖拽效果流程详解

    React实现卡片拖拽效果流程详解

    这篇文章主要介绍了React Web开发实战示例,实现卡片拖拽效果,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习吧
    2022-11-11
  • React合成事件原理解析

    React合成事件原理解析

    事件是在编程时系统内发生的动作或者发生的事情,而开发者可以某种方式对事件做出回应,而这里有几个先决条件,这篇文章主要介绍了React合成事件原理解析,需要的朋友可以参考下
    2022-07-07
  • React diff算法的实现示例

    React diff算法的实现示例

    这篇文章主要介绍了React diff算法的实现示例,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-04-04
  • React应用中使用Bootstrap的方法

    React应用中使用Bootstrap的方法

    本篇文章主要介绍了React应用中使用Bootstrap的方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-08-08
  • react中的DOM操作实现

    react中的DOM操作实现

    某些情况下需要在典型数据流外强制修改子代。要修改的子代可以是 React 组件实例,也可以是 DOM 元素。这时就要用到refs来操作DOM,本文详细的介绍一下使用,感兴趣的可以了解一下
    2021-06-06
  • React传值 组件传值 之间的关系详解

    React传值 组件传值 之间的关系详解

    这篇文章主要介绍了React传值 组件传值 之间的关系详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-08-08
  • JavaScript中React 面向组件编程(下)

    JavaScript中React 面向组件编程(下)

    在React面向组件编程中,除了上一章节的组件实例的三大核心属性以外,还有很多重要的内容比如:React 的生命周期,受控组件与非受控组件,高阶函数和函数柯里化的理解等,在本文中会给大家继续讲解React 面向组件编程中剩余的内容
    2023-03-03
  • react MPA 多页配置详解

    react MPA 多页配置详解

    这篇文章主要介绍了react MPA 多页配置详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-10-10
  • 基于react项目打包css引用路径错误解决方案

    基于react项目打包css引用路径错误解决方案

    这篇文章主要介绍了基于react项目打包css引用路径错误解决方案,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-10-10

最新评论