初始React

<!DOCTYPE html>

<html>

<head>

    <meta charset="UTF-8" />

    <title>React</title>

</head>

<body>

    了解React

    <!-- React是一个用于构建web和原生态交互界面的库

    相对于传统DOM开发优势:组件化开发方式,还有不错的性能

    相较于其他前端框架的优势:有丰富的生态和跨平台支持

    -->

    <!-- 使用create-react-app快速搭建开发环境

    create-react-app是一个快速创建React开发1环境的工具,底层由Webpack构建,封装了配置细节,开箱即用

    执行命令:

    npx create-react-app react-basic

    1.npx Node.js工具命令,查找执行后续的包命令

    2.creat-react-app 核心包(固定写法),用于创建React项目

    3.react-basic React项目的名称(可以自定义)

    在创建好的项目里可以看到package.json文件

    里面的主要依赖是

    "react": "^18.2.0",

    "react-dom": "^18.2.0",

    核心命令是:

    "start": "react-scripts start",

    "build": "react-scripts build",

    刚开始学习建议先把src里的文件清理,只需保留app.js和index.js

    -->

    组件

    <!--

        概念:一个组件就是用户界面的一部分,它可以由自己的逻辑外观,组件之间可以相互嵌套,也可以复用多次

        组件化开发可以让开发者像搭积木一样构建一个完整的庞大的应用

        在React中,一个组件就是首字母大写的函数,内部存放了组件的逻辑和视图UI,渲染组件只需要把组件当成标签书写即可(在App内)

        // 1. 定义组件

        const Button = () => {

        // 业务逻辑组件逻辑

        return <button>click me!</button>

        }

        // 箭头函数定义

       

        function Button(){

        return <button>click me!</button>

        }

        // 常规函数定义

        function App() {

        return (

            <div className="App">

            {/* 2. 使用组件(渲染组件) */}

            {/* 自闭和(单标签) */}

            <Button />

            {/* 成对标签 */}

            <Button></Button>

            </div>

        )

        }

     -->

     useState基础使用

     <!-- useState是一个React Hook(函数),它允许我们向组件添加一个状态变量,从而控制影响组件的渲染结果

          本质:和普通JS变量不同的是,状态变量一旦发生变化,组件的视图UI也会跟着变化(数据驱动视图)

          const [count,setCount] = useState(0)

            // 数组接收useState

          1.useState是一个函数,返回值是一个数组

          2.数组中的第一个参数是状态变量,第二个参数是set函数用来修改状态变量

          3.useState的参数将作为count的初始值

          // useState实现一个计数器按钮

            import { useState } from 'react'

            //引入useState

            // const是不能改变值,但现在是复杂数据类型,修改的是引入地址里面的值,不是修改了引入地址

            function App () {

            // 1. 调用useState添加一个状态变量

            // count 状态变量

            // setCount 修改状态变量的方法

            const [count, setCount] = useState(0)

            // 2. 点击事件回调

            const handleClick = () => {

                // 作用:

                // 1. 用传入的新值修改count

                // 2. 重新使用新的count渲染UI

                setCount(count + 1)

            }

            return (

                <div>

                <button onClick={handleClick}>{count}</button>

                </div>

            )

            }

    -->

    useState修改规则

    <!-- 在React中,状态被认为是只读,我们应该始终替换它而不是修改它,直接修改状态不能引发视图更新

            function App () {

                let [count, setCount] = useState(0)

                const handleClick = () => {

                // 直接修改 无法引发视图更新

                // count++

                // console.log(count)

                setCount(count + 1)

            }

            return (

                <div>

                <button onClick={handleClick}>{count}</button>

                </div>

            )

    -->

            <!-- 修改对象状态

            规则:对于对象类型的状态变量,应该始终传给set方法一个全新的对象来进行修改

            const [form, setForm] = useState({ name: 'jack' })

            const changeForm = () => {

                // 错误写法:直接修改

                // form.name = 'john'

                // 正确写法:setFrom 传入一个全新的对象(新值替换老值)

                setForm({

                ...form,

                // 展开原本有的字段

                name: 'john'

                })

            }

            return (

                <div>

                <button onClick={changeForm}>修改form{form.name}</button>

                </div>

            )

            -->

            组件基础样式方案

            <!--

                1.行内样式(不推荐)

                2.class类名控制

                // 在js文件里导入样式(css)

                import './index.css'

                // 通过类名控制才需要导入

                const style = {

                color: 'red',

                fontSize: '50px'

                }

                function App () {

                return (

                    <div>

                       

                    {/* 行内样式控制 */}

                    <span style={style}>this is span</span>

                    {/* <span style={color: 'red',fontSize: '50px'}>this is span</span> */}

                    {/* 这样写也行 */}

                    {/* 通过class类名控制 */}

                    <span className="foo">this is class foo</span>

                    {/* className是规定好的名字,不能用class */}

                    </div>

                )

                }

            -->

</body>

</html>

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

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

相关文章

https 是否真的安全,https攻击该如何防护,https可以被抓包吗?如何防止呢?

首先解释一下什么是HTPPS 简单来说&#xff0c; https 是 http ssl&#xff0c;对 http 通信内容进行加密&#xff0c;是HTTP的安全版&#xff0c;是使用TLS/SSL加密的HTTP协议 Https的作用&#xff1a; 内容加密 建立一个信息安全通道&#xff0c;来保证数据传输的安全&am…

Doris单机部署——2.0.1.1版本

目录 一、前期准备工作 1.设置系统最大文件打开句柄数 2.时钟同步 3.关闭每台机器的交换分区 4.下载安装包 二、单节点部署安装Doris (一)安装fe 1.解压改名 2.修改配置文件 3.创建元数据目录 4.启动fe 5.访问fe的webUI (二)安装be 1.进入be目录下&#xff0c;修…

Leetcode—35.搜索插入位置【简单】

2023每日刷题&#xff08;四十&#xff09; Leetcode—35.搜索插入位置 实现代码 int lower_bound(int* arr, int numsSize, int tar) {int left 0, right numsSize;int mid;// 左闭右开[left, right)while(left < right) {mid left (right - left) / 2;if(arr[mid] &…

Cadence Vmanager vsif文件编写指南(持续更新...)

目录 1.NTF格式介绍 1.1.1 {属性&#xff1a;值}定义 1.1.2类别 1.1.3语法 2.vsif文件中有效的container 2.1 session {…} 1.NTF格式介绍 Cadence的Vmanager工具采用vsif类型的文件作为regression的输入文件&#xff0c;采用vplanx/csv类型的文件作为vplan的输入文件&am…

攻防非对称问题| 当前企业面临的网络攻防非对称问题及其解决途径

随着信息技术的不断发展&#xff0c;网络已经成为我们日常生活和商业活动中不可或缺的一部分。然而&#xff0c;随之而来的是网络安全问题的不断升级。网络攻防非对称问题是当前亟待解决的一个复杂而严峻的挑战。其主要的表现是攻击成本远低于防御成本以及相同投入带来的攻击能…

BC77 简单计算器(牛客)

#include <stdio.h> int main() {double a, b, d;//用来接收浮点数char c;//用来接受符号scanf("%lf %c %lf", &a, &c, &b);if (c || c - || c * || c /)//判断输入的运算符号不包括在&#xff08;、-、*、/&#xff09;范围内{switch (c)//根…

Kotlin应用——使用kt进行web开发 使用h2database进行初始化数据库 mybatis-plus使用

Kotlin 是一门现代但已成熟的编程语言&#xff0c;旨在让开发人员更幸福快乐。 它简洁、安全、可与 Java 及其他语言互操作&#xff0c;并提供了多种方式在多个平台间复用代码&#xff0c;以实现高效编程。 kt入门的合集文章如下&#xff1a; Kotlin学习——kt入门合集博客 &…

您的计算机已被.halo勒索病毒感染?恢复您的数据的方法在这里!

尊敬的读者&#xff1a; 随着网络威胁的不断演进&#xff0c;Halo勒索病毒作为一种新型威胁正逐渐崭露头角。本文将深入介绍Halo勒索病毒的特点、感染方式&#xff0c;并提供详尽的数据恢复方法&#xff0c;同时分享一些预防措施&#xff0c;以帮助用户更好地保护个人和企业数…

P16 C++构造函数

目录 前言 01 什么是构造函数呢&#xff1f; 02 非构造函数初始化变量 03 构造函数初始化变量 04 带参数的构造函数。 最后的话 前言 我们继续学习 C 的面向对象编程&#xff0c;本章主要是讲其中的 构造函数。 01 什么是构造函数呢&#xff1f; 构造函数基本上是一种特…

tinyViT论文笔记

论文&#xff1a;https://arxiv.org/abs/2207.10666 GitHub&#xff1a;https://github.com/microsoft/Cream/tree/main/TinyViT 摘要 在计算机视觉任务中&#xff0c;视觉ViT由于其优秀的模型能力已经引起了极大关注。但是&#xff0c;由于大多数ViT模型的参数量巨大&#x…

MetaObject-BeanWrapper-MetaClass-Reflector的关系

MetaObject、BeanWrapper、MetaClass、Reflector之间是通过装饰器模式逐层进行装饰的。其中MetaObject、BeanWrapper是操作对象&#xff1b;MetaClass、Reflector是操作Class ObjectWrapper类结构图 BaseWrapper是对BeanWrapper、MapWrapper公共方法的提取及类图的优化&#…

线程的创建方式

作者简介&#xff1a; zoro-1&#xff0c;目前大二&#xff0c;正在学习Java&#xff0c;数据结构&#xff0c;mysql&#xff0c;javaee等 作者主页&#xff1a; zoro-1的主页 欢迎大家点赞 &#x1f44d; 收藏 ⭐ 加关注哦&#xff01;&#x1f496;&#x1f496; 线程的创建方…

知识点小总结

‘Integer(int)‘ 已经过时了 https://blog.csdn.net/qq_43116031/article/details/127793512 解决Java中的“找不到符号“错误 解决Java中的“找不到符号“错误_java: 找不到符号_很酷的站长的博客-CSDN博客 可右键打开 错误: 编码 UTF-8 的不可映射字符 错误: 编码 UTF-8 …

Less的函数的介绍

文章目录 前言描述style.less输出后言 前言 hello world欢迎来到前端的新世界 &#x1f61c;当前文章系列专栏&#xff1a;Sass和Less &#x1f431;‍&#x1f453;博主在前端领域还有很多知识和技术需要掌握&#xff0c;正在不断努力填补技术短板。(如果出现错误&#xff0c;…

OD机考真题搜集:导师请吃火锅

题目 入职后,导师会请你吃饭,你选择了火锅, 火锅里会在不同时间下很多菜, 不同食材要煮不同时间,才能变得刚好合适, 你希望吃到最多的刚好合适的菜, 但是你的手速不够快用m代替手速, 每次下手捞菜后至少要过m秒, 才能再捞(每次只能捞一个)那么用最合理的策略, 最多…

什么是无监督学习

1 概况 1.1 定义 无监督学习&#xff08;Unsupervised Learning&#xff09;是机器学习的一种类型&#xff0c;它涉及从未标记的数据中发现隐藏的模式。与监督学习不同&#xff0c;无监督学习的数据没有显式的标签或已知的结果变量。其核心目的是探索数据的内在结构和关系。无…

PTA-6-46 手机接口-适配器模式

题目&#xff1a; 用适配器模式编写程序代码。设计一个接口Phone&#xff0c;包含五个抽象方法&#xff1a;dial ()、location()、photo()、music()、video()&#xff0c;分别表示拨号、定位、拍照、音乐、视频功能。定义一个抽象类实现接口所有方法&#xff0c;以及定义两个子…

Less 嵌套规则

文章目录 前言描述style.less输出后言 前言 hello world欢迎来到前端的新世界 &#x1f61c;当前文章系列专栏&#xff1a;Sass和Less &#x1f431;‍&#x1f453;博主在前端领域还有很多知识和技术需要掌握&#xff0c;正在不断努力填补技术短板。(如果出现错误&#xff0c;…

数据库基础教程之创建触发器,实现自动更新时间戳(四)

postgresql 更新时间戳需要通过触发器来实现,这里给出两种方法来实现。 创建字段create_time和edit_time 通过Navicat在添加字段时候将字段设置为timestamp类型,生成时间戳方式为CURRENT_TIMESTAMP或者设置为now(),然后点击保存。 新建函数 点击函数,然后在弹出的函数向导中…

斐波那契数(力扣LeetCode)动态规划

斐波那契数&#xff08;力扣LeetCode&#xff09;动态规划 题目描述 斐波那契数 &#xff08;通常用 F(n) 表示&#xff09;形成的序列称为 斐波那契数列 。该数列由 0 和 1 开始&#xff0c;后面的每一项数字都是前面两项数字的和。也就是&#xff1a; F(0) 0&#xff0c;F…