了解JSX

在React中使用JSX

<!DOCTYPE html>

<html>

<head>

    <meta charset="UTF-8" />

    <title>JSX</title>

</head>

<body>

    JSX

    <!-- JSX

    概念:JSX是JavaScript和XML的缩写,表示在js代码中编写HTML

    模板结构,它是React中编写UI模板的方式

    优势:HTML的声明模板写法,JS的可编程能力

    本质:JSX并不是标准的JS语法,它是JS的语法扩展,浏览器本身不能识别,需要通过解析工具左解析之后才能在浏览器中运行

    -->

    JSX中使用JS表达式

    <!--JSX中使用JS表达式

        在JSX中可以通过大括号语法{}识别JavaScript中的表达式,比如常见的变量,函数调用,方法调用等等

        1.使用引号传递字符串

        2.使用JavaScript变量

        3.函数调用和方法调用

        4.使用JavaScript对象

     -->

     <!--

        const count =100

        function getname(){

        return 'jack'

        }

        function App() {

        // return里面就是JSX

        return (

            <div className="App">

            this is app

            {/* 字符串 */}

            {'this is message'}

            {/* JavaScript变量 */}

            {count}

            {/* 函数调用 */}

            {getname()}

            {/* 方法调用 */}

            {new Date().getDate()}

            {/* JS对象 */}

            <div style={{color:'red'}}>this is div</div>

           

            {/* 外层{}是识别表达式的语法,内层{}是识别对象结构 */}

            {/* 注意:只有表达式可以识别,if语句,switch语句,声明变量属于语句,不是表达式,不能出现在{}中*/}

            -->

            渲染列表

            <!-- 渲染列表

           

                const list = [

                { id: 1001, name: 'Vue' },

                { id: 1002, name: 'React' },

                { id: 1003, name: 'Angular' }

            ]  

            <div className="App">

                {/* 渲染列表 */}

                {/* map 循环哪个结构 return结构 */}

                {/* 注意事项:加上一个独一无二的key 字符串或者number id */}

                {/* key的作用:React框架内部使用 提升更新性能的 */}

                <ul>

                    {list.map(item => <li key ={item.id} >{item.name}</li>)}

                </ul>

            </div>

            -->

            JSX中实现条件渲染

            <!-- 语法:在React中可以通过逻辑与运算符&&,三元表达式(?:)实现基础的条件渲染 -->

            <!--

                const isLogin = true

                function App () {

                return (

                    <div className="App">

                    {/* 逻辑与 && */}

                    {isLogin && <span>this is span</span>}

                    {/* 三元运算 */}

                    {isLogin ? <span>jack</span> : <span>loading...</span>}

                    </div>

                )

                }

             -->

             复杂条件渲染

             <!--

                // 定义文章类型

                const articleType = 3  // 0 1 3

                // 定义核心函数(根据文章类型返回不同的JSX模版)

                function getArticleTem () {

                    if (articleType === 0) {

                        return <div>我是无图文章</div>

                    } else if (articleType === 1) {

                        return <div>我是单图模式</div>

                    } else {

                        return <div>我是三图模式</div>

                    }

                }

                function App () {

                    return (

                        <div className="App">

                        {/* 调用函数渲染不同的模版 */}

                        {getArticleTem()}

                        </div>

                    )

                }

              -->

              React基础事件绑定

              <!-- 基础语法:on+事件名称 = {事件处理程序},整体上遵循驼峰命名法

                   使用事件对象参数,语法:在事件回调函数中设置形参e

                   注意:不能直接写函数调用,这里事件绑定需要一个函数引用

                     // 基础绑定

                    // const handleClick = () => {

                    //   console.log('button被点击了')

                    // }

                    return (

                    <div className="App">

                    <button onClick={handleClick}>click me </button>

                    </div>

                    // 事件参数e

                    // const handleClick = (e) => {

                    //   console.log('button被点击了', e)

                    // }

                    return (

                    <div className="App">

                    <button onClick={handleClick}>click me </button>

                    </div>

                    // 传递自定义参数

                    // const handleClick = (name) => {

                    //   console.log('button被点击了', name)

                    // }

                    return (

                    <div className="App">

                    <button onClick={() => handleClick('jack')}>click me </button>

                    </div>

                    // 既要传递自定义参数 而且还要事件对象e

                    const handleClick = (name, e) => {

                        console.log('button被点击了', name, e)

                    }

                    return (

                        <div className="App">

                        <button onClick={(e) => handleClick('jack', e)}>click me </button>

                       

                        </div>

                    )

                    }

            -->

</body>

</html>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/172668.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

初次使用vs code时go模块安装失败的解决办法

问题分析 go语言在vs code中下载模块时&#xff0c;会使用自己的代理&#xff0c;这个代理在大陆无法访问&#xff0c;需要将代理修改为国内的&#xff0c;模块就可以正常下载了&#xff0c;阿里的代理我试过了&#xff0c;有问题。 解决步骤 确保已经配置了go的环境变量&am…

开源与闭源:大模型未来的发展之争

在当今数字化时代&#xff0c;开源与闭源软件一直是技术界争论的热点话题。随着人工智能技术的快速发展&#xff0c;特别是大模型&#xff08;如GPT-4等&#xff09;的广泛应用&#xff0c;这个辩论在大模型技术的背景下变得更加引人注目。本文将探讨开源与闭源的优劣势比较&am…

WordPress无需插件禁用WP生成1536×1536和2048×2048尺寸图片

我们在使用WordPress上传图片媒体文件的时候&#xff0c;是不是看到媒体库中有15361536和20482048的图片文件&#xff0c;当然这么大的文件会占用我们的服务器空间&#xff0c;如何禁止掉呢&#xff1f; function remove_default_image_sizes( $sizes) {unset( $sizes[1536x15…

spring-webmvc练习-日程管理-访问后端展示列表数据

1、util/request.js import axios from "axios";let request axios.create({baseURL: "http://localhost:8080",timeout: 50000 });export default request 2、api/schedule.js import request from "../util/request.js";export let getSchedu…

[架构之路-253]:目标系统 - 设计方法 - 软件工程 - 软件设计 - 结构化设计的主要评估指标:高内聚(模块内部)、低耦合(模块之间)的含义

目录 前言&#xff1a; 一、软件工程中的软件设计种类&#xff1a;根据宏观到微观分 &#xff08;1&#xff09;软件架构设计&#xff08;层次划分、模块划分、职责分工&#xff09;&#xff1a; &#xff08;2&#xff09;软件高层设计、概要设计&#xff08;功能模块的接…

【c++随笔14】虚函数表

【c随笔14】虚函数表 一、虚函数表&#xff08;Virtual Function Table&#xff09;1、定义2、查看虚函数表2.1、 问题&#xff1a;三种类型&#xff0c;包含一个int类型的class、一个int类型的变量、int类型的指针&#xff1a;这三个大小分别是多少呢&#xff1f;2.2、怎么发现…

Vue项目创建

1.首先按WinR&#xff0c;输入cmd&#xff0c;开启命令行 2.跳转到项目目标位置&#xff0c;比如我的项目创建位置是E:\Vue-test&#xff0c;因而输入&#xff1a; e: cd E:\Vue-test 3.输入npm init vuelatest&#xff08;初始化Vue&#xff09;&#xff0c;如果是第一次用…

IT问题解答类型网站源码

问答网是一款为IT工程师提供的问答平台&#xff0c;旨在帮助用户在线获取专业知识和相关问题的答案。在问答网&#xff0c;用户可以轻松找到其他人的问答问题&#xff0c;并在这里寻求解答。如果您有任何想要解决的问题&#xff0c;都可以在此发布问题并得到其他同行的解答。 …

kafka kraft 集群搭建保姆级教学 包含几个踩坑点

一.为啥弃用zookeeper kafka 弃用 ZooKeeper 而采用 KRaft 的主要原因是为了改进 Kafka 集群的可靠性和可管理性。 在传统的 Kafka 架构中&#xff0c;ZooKeeper 用于存储和管理集群的元数据、配置信息和状态。然而&#xff0c;使用 ZooKeeper 作为协调服务存在一些限制和挑战…

CSS之弹性盒子Flexible Box

我想大家在做布局的时候&#xff0c;没接触flex布局之前&#xff0c;大家都是用浮动来布局的&#xff0c;但现在我们接触了flex布局之后&#xff0c;我只能说&#xff1a;“真香”。让我为大家介绍一下弹性盒子模型吧&#xff01; Flexible Box 弹性盒子 在我们使用弹性盒子时&…

bootstrap 5 登录、注册页面

bootstrap 5 登录、注册页面 <!DOCTYPE html> <html lang"en"> <head> <meta charset"UTF-8"> <meta name"viewport" content"widthdevice-width, initial-scale1.0"> <title>Login Page…

【算法】链表-20231127

这里写目录标题 一、面试题 02.02. 返回倒数第 k 个节点二、82. 删除排序链表中的重复元素 II三、141. 环形链表 一、面试题 02.02. 返回倒数第 k 个节点 提示 简单 130 相关企业 实现一种算法&#xff0c;找出单向链表中倒数第 k 个节点。返回该节点的值。 注意&#xff1a;本…

Linux(8):BASH

硬件、核心与 Shell 操作系统其实是一组软件&#xff0c;由于这组软件在控制整个硬件与管理系统的活动监测&#xff0c;如果这组软件能被用户随意的操作&#xff0c;若使用者应用不当&#xff0c;将会使得整个系统崩溃。因为操作系统管理的就是整个硬件功能。 应用程序在最外层…

前端(HTML + CSS + JS)

文章目录 一、HTML1. 概念&#xff08;1&#xff09;HTML 文件基本结构&#xff08;2&#xff09;HTML代码框架 2. 、HTML常见标签 二、CSS1. CSS基本语法规范2. 用法&#xff08;1&#xff09; 引用方式&#xff08;2&#xff09;选择器&#xff08;3&#xff09;常用元素属性…

NX二次开发UF_CURVE_ask_trim 函数介绍

文章作者&#xff1a;里海 来源网站&#xff1a;https://blog.csdn.net/WangPaiFeiXingYuan UF_CURVE_ask_trim Defined in: uf_curve.h int UF_CURVE_ask_trim(tag_t trim_feature, UF_CURVE_trim_p_t trim_info ) overview 概述 Retrieve the current parameters of an a…

利用STM32和MFRC522 IC实现智能卡的读取和数据存储

利用STM32微控制器和MFRC522 RFID读写器芯片&#xff0c;可以实现智能卡的读取和数据存储功能。智能卡是一种集成了RFID技术和存储芯片的卡片&#xff0c;它可以用于身份验证、门禁控制、支付系统等应用场景。下面将介绍如何使用STM32和MFRC522芯片进行智能卡的读取和数据存储&…

3.OpenResty系列之Nginx反向代理

1. Nginx简介 Nginx (engine x) 是一款轻量级的 Web 服务器 、反向代理服务器及电子邮件&#xff08;IMAP/POP3&#xff09;代理服务器 什么是反向代理&#xff1f; 反向代理&#xff08;Reverse Proxy&#xff09;方式是指以代理服务器来接受 internet 上的连接请求&#x…

4面试题--数据库(补充)

隔离性问题 若不考虑隔离性则会出现以下问题 1. 脏读&#xff1a;指⼀个事务在处理数据的过程中&#xff0c;读取到另⼀个 未提交 事务的数据 2. 不可重复读&#xff1a;指对于数据库中的某个数据&#xff08;同⼀个数据项&#xff09;&#xff0c;⼀个事务内的多次查询却…

docker打包前端镜像

文章目录 一、构建镜像二、查看本地镜像三、启动容器四、查看启动的容器五、保存镜像六、读取镜像七、创建镜像八、最后 docker官网 一、构建镜像 -t是给镜像命名&#xff0c;.(点)是基于当前目录的Dockerfile来构建镜像 docker build -t image_web .二、查看本地镜像 docke…

使用echars实现数据可视化

生活随笔 展翅飞翔之际 请下定决心不再回头 echars实现数据可视化 在搭建后台页面时&#xff0c;可能会遇到很多的表格&#xff0c;但有时表格所展现的数据并不能直观的体现出当前用户的宏观信息&#xff0c;所以就可以引入一个新的表格插件——echars 快速上手 - Handbook…