2024年前端最全制作渐变背景生成器 - React State和Event教程,kotlin教程

本文详细介绍了HTTP协议的基础概念,如报文结构、请求方法、URI和状态码,以及在前端开发中如何处理颜色选择、表单数据、大文件传输等问题,并结合React组件实例,探讨了如何使用create-react-app和ReactHooks实现动态渐变效果。
摘要由CSDN通过智能技术生成

HTTP

  • HTTP 报文结构是怎样的?

  • HTTP有哪些请求方法?

  • GET 和 POST 有什么区别?

  • 如何理解 URI?

  • 如何理解 HTTP 状态码?

  • 简要概括一下 HTTP 的特点?HTTP 有哪些缺点?

  • 对 Accept 系列字段了解多少?

  • 对于定长和不定长的数据,HTTP 是怎么传输的?

  • HTTP 如何处理大文件的传输?

  • HTTP 中如何处理表单数据的提交?

  • HTTP1.1 如何解决 HTTP 的队头阻塞问题?

  • 对 Cookie 了解多少?

  • 如何理解 HTTP 代理?

  • 如何理解 HTTP 缓存及缓存代理?

  • 为什么产生代理缓存?

  • 源服务器的缓存控制

  • 客户端的缓存控制

  • 什么是跨域?浏览器如何拦截响应?如何解决?

    开源分享:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】

等同于

npx create-react-app react-gradient-bg

创建 Gradient 组件


工程创建好之后,咱们在 src 里面创建一个新的组件 (也就是文件夹) 叫 Gradient

这个简单的示例的代码整个都在这个 gradient 组件里边。他有两个颜色选>择器。然后一个重置按钮。整个背景是由用户选择的两个颜色组成的一个 75 度的渐变。当用户在选择颜色的时候,这个背景会动态的根据用户选择的颜色发生变化,点击重置按钮之后,背景颜色会变成初始的默认值。

咱们先来看 html 的结构。

编写 html 结构

function Gradient() {

重置为默认

;

}

这里:

  • 定义了两个 typecolorinput,这是 html 原生的颜色选择器组件, 如果浏览器不支持就会变成颜色输入框,可以输入#FFFFFF 之类的颜色值。

  • 定义了一个重置按钮。

  • 样式可以在源代码中查看。

创建 state

创建 state 用 react 内置的 useState hook。

// 设置两个 state,给默认值

const [color1, setColor1] = useState(“#00F260”);

const [color2, setColor2] = useState(“#0575E6”);

  • 它接受一个参数,是 state 的默认值,然后返回一个数组,数组里面有两个元素,第 1 个元素是 state 的值,然后第 2 个元素是改变这个 state 的函数。

  • 这里定义了两个 color state。

接着给最外层容器 div 设置一个 style,让它的背景色为渐变的,使用这两个 color 的值:

return (

className={styles.container}

style={{

background: linear-gradient(75deg, ${color1}, ${color2})

}}

// …

处理 input 事件

接下来就是处理这两个颜色状态的改变,表单元素 input、 select 等会触发 onChange 这个事件,也就是说当用户在里边输入值或者是选择选项的时候。

咱们可以在这个组件的函数里边,先定义一个处理函数。比如说叫 handleInputChange

function handleInputChange(e) {

const { name, value } = e.target;

// 使用 name 区分,这里也可以用 switch

if (name === “color1”) {

setColor1(value);

} else if (name === “color2”) {

setColor2(value);

}

}

  • react 会在触发事件的时候,给事件处理函数传递一个参数 event,代表这个事件它的本身,但是这个事件是合成的,它不是原生的 html 的 event,不过它里面的属性和 html 的基本上一样。

  • 这个 event 里面有一个 target 属性,就是说是谁触发了一个事件,那这里就是这两个 input。

  • 获取到 input 的 target 之后就可以获取到 input 标签里面的属性,比如说 namevalue

  • 后面可以根据 name 来区分是哪个 input 触发的事件,然后把新的颜色用 setXXX 的函数,来把颜色更新。

最后把处理函数和状态的值添加到 input 组件上,注意在 JSX 里边,html 的属性都是驼峰命名法,不是全部小写的那种:

<input

type=“color”

name=“color1”

className={styles.inputColor}

value={color1}

onChange={handleInputChange}

/>

<input

type=“color”

name=“color2”

className={styles.inputColor}

value={color2}

onChange={handleInputChange}

/>

处理按钮事件

定义按钮的处理函数,用来重置颜色为默认值:

// 重置按钮事件

function handleClick() {

setColor1(“#00F260”);

读者福利

========

开源分享:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】

由于篇幅过长,就不展示所有面试题了,想要完整面试题目的朋友(另有小编自己整理的2024大厂高频面试题及答案附赠)


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值