REACT学习DAY02(恨连接不上服务器)

受控表单绑定

概念:使用React组件的状态(useState)控制表单的状态

1. 准备一个React状态值

const [value,setValue] = useState('')

2. 通过value属性绑定状态,通过onChange属性绑定状态同步的函数

<input
type="text"
value={value}
onChange={(e) => setValue(e.target.value)}
/>

React中获取DOM

在 React 组件中获取/操作 DOM,需要使用 useRef React Hook钩子函数,分为两步:

1. 使用useRef创建 ref 对象,并与 JSX 绑定

const inputRef = useRef(null)
<input type="text" ref={inputRef} />

2. 在DOM可用时,通过 inputRef.current 拿到 DOM 对象

八老师说贺越说要先看千锋捏

所以转战 了

感觉自己有点理解了react基本使用?

 这他喵不是和黑马是两个东西吗

当时豆包建议我下的

这个脚手架需要较高版本的Node.js(14.18+,16+)

然后可以

npm create vite@latest

在安装的时候可以选JS或者JS+SWC

所以我们选择JS+SWC

 在文件上面vite.svg是没有被编译过的

使用npm run build就是把它给打包

逆天追踪

已经取消了

只能说我的服务器挂了和我也脱不开关系

ESLint配置与Prettier配置

ESLint是代码规范插件

npm run lint
vite-plugin-eslint

Prettier是代码格式化插件

下载一个这个东西

 然后还是按Alt+Shift+F就格式化了

React模块与react-dom模块分别起什么作用

react模块有核心功能和组件

react-dom模块是操作浏览器DOM,react-dom/server

JSX与HTML之间写法的区别

首先是标签要小写、必须闭合

然后是类选择器要写成className

for属性要换成htmlFor

<label htmlFor="elem">用户名</label>

属性是采取驼峰命名法

大括号使用JS

但是对象和函数不能直接放到JSX的{}中

属性可以使用 大括号渲染

只有唯一的根元素

import { Fragment } from 'react'

这个相当于一个容器,简写就是空箭头

<></>

区别是Fragment可以添加key属性

行间样式、全局样式、局部样式的使用

function App(){
    return(
        <div style={{width:'100px',height:'100px',background:'red'}}>hello</div>
    )
}

export default App

写的东西最后会通过脚手架编译成新的东西

引用的话需要这样写:

<div className={style.box2}>aaa</div>
<div className={style['head-title']}>bbbbb</div>

当把配置改一下之后就好用了,这是vite.config.js:

import { defineConfig } from 'vite'
import react from '@vitejs/plugin-react-swc'
import eslintPlugin from 'vite-plugin-eslint'

// https://vite.dev/config/
export default defineConfig({
  plugins: [
    react(),
    eslintPlugin({
      include: ['src/*.jsx', 'src/**/*.jsx'],
    }),
  ],
  css:{
    modules:{
      localsConvention:'camelCase'
    }
  }
})

把它变成这样加一个css之后就可以使用驼峰命名使用引入的样式了

支持sass预处理和classnames模块的使用

怎么支持预处理呢?

执行一下这个命令:

npm install sass

每一次的旋转都是对我小心脏的锻炼

就怕又断联了

sass.scss

$bg:red;

.box3{
    background-color: $bg;
}

classname模块又是在干嘛的呢?

继续添加一个包:

npm install classnames

import classNames from 'classnames'

function App(){
    const myClass = classNames({
        box1:true,
        box2:false,
    })
    return(
        // <div className={ myClass.join(' ')}>
        //     Hello App
        // </div>
        <>
            <div className={myClass}>
                hello App
            </div>
        </>
    )
}

export default App

还可以用其他的:

React元素是如何添加事件操作

event合成事件,可以解决一些事件的处理

事件委托到容器元素

如何根据不同的条件进行不同的内容渲染

function App(){
    let count = 0
    return (
        <div>
            Hello App
            <br />
            {count >3 ? <div>hello react</div> :  <p>hi JavaScript</p>}
        </div>
    )
}
export default App

别的类型+空字符串是转换成字符串类型

但是对象加上空字符串转成的是不同的格式

对一个数据集合进行批量渲染

循环语句:for,while

JSX中默认对数组进行join()操作

数组方法:map

列表渲染需要添加key属性。这些key会告诉react,每个组件里面对应着数组的哪一项,可以帮助React推断发生了什么,从而得以正确地更新DOM树


// function App(){
//     const list = ['aaaa','bbbb','cccc']
//     for(let i=0;i<list.length;i++)
//     {
//         list[i] = <li>{list[i]}</li>
//     }
//     return (
//         <div>hello App
//             hello App
//             <br />
//             <ul>
//                 {list}
//             </ul>
//         </div>
//     )
// }

// export default App

function App(){
    const list = ['aaaa','bbbb','cccc']
    // for(let i=0;i<list.length;i++)
    // {
    //     list[i] = <li>{list[i]}</li>
    // }
    return (
        <div>
            hello App
            <br />
            <ul>
                { list.map((item,index)=><li key={index}>{item}</li>) }
            </ul>
        </div>
    )
}

export default App

两种实现组件的标记写法

const Qf = {
  Welcome() {
    return <div>hello Welcome</div>
  },
}

const { Welcome } = Qf

function App() {
  return (
    <div>
      hello App
      <Qf.Welcome></Qf.Welcome>
      <Welcome></Welcome>
    </div>
  )
}

export default App

还有一种函数的写法

react/display-name 规则要求每个 React 组件都应该有一个显示名称,在开发者工具和错误信息里,显示名称有助于识别组件。对于函数式组件,通常函数名会被当作显示名称,但对于像 Qf.Welcome 这样的嵌套组件,ESLint 可能无法自动识别显示名称。

所以需要手动设置(我看千峰的上面没有要求这个,可能是我用的这个版本高)

const Qf=()=>{
    return (
        <div>
            hello Qf
        </div>
    )
}

// 手动设置 Qf 组件的显示名称
Qf.displayName = 'Qf';

Qf.Welcome=()=>{
    return (<div>hello Welcome</div>)
}

// 手动设置 Qf.Welcome 组件的显示名称
Qf.Welcome.displayName = 'Qf.Welcome';

function App() {
  return (
    <div>
      hello App
      <Qf/>
      <Qf.Welcome></Qf.Welcome>
    </div>
  )
}

export default App

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

一周学会Flask3 Python Web开发-response响应格式

锋哥原创的Flask3 Python Web开发 Flask3视频教程&#xff1a; 2025版 Flask3 Python web开发 视频教程(无废话版) 玩命更新中~_哔哩哔哩_bilibili 在HTTP响应中&#xff0c;数据可以通过多种格式传输。大多数情况下&#xff0c;我们会使用HTML格式&#xff0c;这也是Flask中…

深度学习基础--ResNet网络的讲解,ResNet50的复现(pytorch)以及用复现的ResNet50做鸟类图像分类

&#x1f368; 本文为&#x1f517;365天深度学习训练营 中的学习记录博客&#x1f356; 原作者&#xff1a;K同学啊 前言 如果说最经典的神经网络&#xff0c;ResNet肯定是一个&#xff0c;这篇文章是本人学习ResNet的学习笔记&#xff0c;并且用pytorch复现了ResNet50&…

linux 驱动编程配置(minis3c2440)

1.介绍 1. 启动过程&#xff1a;启动u-boot------>>启动linux内核----->>挂载根文件系统 2. uboot是一个裸机程序&#xff0c;是一个bootloader&#xff0c;用于启动linux系统以及系统初始化 ubootloader主要完成了哪些任务&#xff1a;1. 初始化异常向量表&a…

【Excel】【VBA】根据内容调整打印区域

Excel VBA&#xff1a;自动调整打印区域的实用代码解析 在Excel中&#xff0c;我们经常需要调整打印区域。今天介绍一段VBA代码&#xff0c;它可以根据C列的内容自动调整打印区域。 Dim ws As Worksheet Dim lastRow As Long Dim r As Long 设置当前工作表 Set ws ActiveSh…

wps中zotero插件消失,解决每次都需要重新开问题

参考 查看zotero目录 D:\zotero\integration\word-for-windows 加载项点击 dotm即可 长期解决 把dom 复制到 C:\Users\89735\AppData\Roaming\kingsoft\office6\templates\wps\zh_CN还是每次都需要重新开的话 重新加载一下

【Java八股文】09-计算机操作系统面试篇

文章目录 计算机操作系统面试篇用户态和内核态的区别&#xff1f;用户态和内核态的区别&#xff1f; 进程管理线程和进程的区别是什么&#xff1f;进程&#xff0c;线程&#xff0c;协程的区别是什么&#xff1f;创建一个协程的过程线程运行过程中申请到的东西在切换时是否全部…

CPU安装pytorch(别点进来)

终于&#xff01; 深度学习环境配置5——windows下的torch-cpu1.2.0环境配置_requirement怎么写torch cu-CSDN博客

echarts找不到了?echarts社区最新地址

前言&#xff1a;在之前使用echarts的时候&#xff0c;还可以通过上边的导航栏找到echarts社区&#xff0c;但是如今的echarts变更之后&#xff0c;就找不到echarts社区了。 ✨✨✨这里是秋刀鱼不做梦的BLOG ✨✨✨想要了解更多内容可以访问我的主页秋刀鱼不做梦-CSDN博客 如今…

什么是事务?并发事务引发的问题?什么是MVCC?

文章目录 什么是事务&#xff1f;并发事务引发的问题&#xff1f;什么是MVCC&#xff1f;1.事务的四大特性2.并发事务下产生的问题&#xff1a;脏读、不可重复读、幻读3.如何应对并发事务引发的问题&#xff1f;4.什么是MVCC&#xff1f;5.可见性规则&#xff1f;参考资料 什么…

【算法基础】--前缀和

前缀和 一、一维前缀和示例模板[寻找数组的中心下标 ](https://leetcode.cn/problems/tvdfij/description/)除自身以外的数组乘积和可被k整除的子数组 一、一维前缀和 前缀和就是快速求出数组某一个连续区间内所有元素的和。 示例模板 已知一个数组arr&#xff0c;求前缀和 …

【含文档+PPT+源码】基于Django的新闻推荐系统的设计与实现

项目介绍 本课程演示的是一款基于Django的新闻推荐系统的设计与实现&#xff0c;主要针对计算机相关专业的正在做毕设的学生与需要项目实战练习的 Python学习者。 1.包含&#xff1a;项目源码、项目文档、数据库脚本、软件工具等所有资料 2.带你从零开始部署运行本套系统 3.…

内容中台架构下智能推荐系统的算法优化与分发策略

内容概要 在数字化内容生态中&#xff0c;智能推荐系统作为内容中台的核心引擎&#xff0c;承担着用户需求与内容资源精准匹配的关键任务。其算法架构的优化路径围绕动态特征建模与多模态数据融合展开&#xff0c;通过深度强化学习技术实现用户行为特征的实时捕捉与动态更新&a…

如何在WPS打开的word、excel文件中,使用AI?

1、百度搜索&#xff1a;Office AI官方下载 或者直接打开网址&#xff1a;https://www.office-ai.cn/static/introductions/officeai/smartdownload.html 打开后会直接提示开始下载中&#xff0c;下载完成后会让其选择下载存放位置&#xff1a; 选择位置&#xff0c;然后命名文…

QML 实现一个动态的启动界面

QML 实现一个动态的启动界面 一、效果查看二、源码分享三、所用到的资源下载 一、效果查看 二、源码分享 工程结构 main.qml import QtQuick import QtQuick.Controls import QtQuick.Dialogs import Qt.labs.platformWindow {id:windowwidth: 640height: 400visible: truetit…

springboot之解析请求参数时,无法获取方法参数的名称。

主要报错信息&#xff1a; java.lang.IllegalArgumentException: Name for argument of type [java.lang.Integer] not specified, and parameter name information not available via reflection. Ensure that the compiler uses the ‘-parameters’ flag. 改bug过程&#x…

开源免费文档翻译工具 可支持pdf、word、excel、ppt

项目介绍 今天给大家推荐一个开源的、超实用的免费文档翻译工具&#xff08;DeeplxFile&#xff09;&#xff0c;相信很多人都有需要翻译文档的时刻&#xff0c;这款工具就能轻松解决你的需求。 它支持多种文档格式翻译&#xff0c;包括 Word、PDF、PPT、Excel &#xff0c;使…

Github 开源 AI 知识库推荐

今天来聊聊那些好用的 GitHub 上开源的 AI 知识库。这些项目不仅能让开发者们快速上手&#xff0c;还能帮助我们解决实际问题&#xff0c;甚至让我们的应用更加智能化。它们为企业、开发者和研究人员提供了强大的工具&#xff0c;用于管理和查询海量的知识信息。废话不多说&…

uni-app开发app时 使用uni.chooseLocation遇到的问题

问题一&#xff1a;不显示 问题二&#xff1a;选择地址列表一直在加载中 因为 uni-app 接口文档 中已经说明&#xff0c;使用腾讯的话需要开启云服务&#xff0c;具体可看官网&#xff0c;这就是为什么使用时直接不显示的原因&#xff0c;所以我使用的高德&#xff0c;但又出现…

Cython学习笔记1:利用Cython加速Python运行速度

Cython学习笔记1&#xff1a;利用Cython加速Python运行速度 CythonCython 的核心特点&#xff1a;利用Cython加速Python运行速度1. Cython加速Python运行速度原理2. 不使用Cython3. 使用Cython加速&#xff08;1&#xff09;使用pip安装 cython 和 setuptools 库&#xff08;2&…

【Deepseek】Linux 本地部署 Deepseek

前言 本文介绍在 Linux 系统上部署 Deepseek AI。本文教程是面向所有想体验 AI 玩家的一个简易教程&#xff0c;因此即使是小白也可以轻松完成体验&#xff0c;话不多说立马着手去干。 [注]&#xff1a;笔者使用的系统为 Ubuntu 24.10 1. 关于 ollama Ollama 是一款开源应用…