【React】React入门--更改状态、属性、表单的非受控组件和受控组件

简介: 更改状态、属性、表单的非受控组件和受控组件

🎀个人主页:努力学习前端知识的小羊

感谢你们的支持:收藏🎄 点赞🍬 加关注🪐


setState

this.state是纯js对象,在vue中,data属性是利用object.defineProperty处理过的,更改data数据的时候会触发数据的getter和setter,但是React没有做这样的处理,所以不能直接更改this.state中的值,需要使用特殊的更改状态的方法setState

以下方代码为例,对button按钮绑定onClick事件,点击按钮,改变this.state中的myshow值和myname值,从而判断是收藏还是取消收藏

export default class App extends Component {
    constructor(){
        super()
        this.state = {
            mytext:"收藏",
            myshow:true,
            myname:"kerwin"
        }
    }
  render() {
    return (
      <div>
        <h1>欢迎来到React开发-{this.state.myname}</h1>
        <button onClick={()=>{
            this.setState({
                myshow:!this.state.myshow,
                myname:"xiaoming"
            }) //间接修改收藏
            if(this.state.myshow){
                console.log("收藏的逻辑");
            } else{
                console.log("取消收藏的逻辑");
            }
        }}>{this.state.myshow?"收藏":"取消收藏"}</button>
      </div>
    )
  }
}

setState有两个参数

第一个参数可以是对象,也可以是方法return一个对象

  • 参数是对象
this.setState({
                myshow:!this.state.myshow,
                myname:"xiaoming"
            }) 
  • 参数是方法
this.setState((prevState,props)=>{
  return {
  myshow:!prevState.myshow,
    }
})

该方法中接受了两个参数,一个是上一次的state,一个是pops

属性(props)

props是外部传入的数值,组件内部也可以通过一些方式进行初始化的设置,属性不能被组件自己更改,但是可以通过父组件组东重新渲染的方式来传入新的props

props的使用:在使用一个组件的时候,可以把参数放在标签的属性当中,这些属性都会作为组件props对象的键值

  • 在组件上通过key=value写属性,通过this.props获取属性
  • 在传参时候,如果写成isshow = "true"那么传过去的数值是一个字符串,如果写成isshow = {true}这时传过去的是布尔值
  • {…对象}利用ES6展开赋值
  • 默认属性值
// 默认属性
    static defaultProps={
        leftshow:true  //如果组件中没有传leftshow的键值,则默认leftshow值为true
    }
  • 属性验证prop-types


import kerwinPropTypes from 'prop-types'
    //   类属性
    static propTypes ={
        title:kerwinPropTypes.string,  //验证数值是否为字符串
        leftshow:kerwinPropTypes.bool  // 验证数值是否为布尔值
    }

属性vs状态

相似点:都是纯js对象,都会触发render更新,都具有确定性(状态/属性相同,结果相同)

不同点:

  • 属性能从父组件获取,状态不能
  • 属性可以由父组件修改,状态不能
  • 属性能在内部设置默认值,状态也可以,设置方式不一样
  • 属性不在组件内部修改,状态要在组件内部修改
  • 属性能设置子组件初始值,状态不可以
  • 属性可以修改子组件的值,状态不可以

state的主要作用是用于组件保存、控制、修改自己的可变状态。state在组件内部初始化,可以被组件自身修改,而外部不能访问也不能修改。state中状态可以通过this.setstate方法进行更新,setstate会导致组件的重新渲染。

props的主要作用是让使用该组件的父组件可以传入参数来配置该组件。它是外部传进来的配置参数,组件内部无法控制也无法修改。除非外部组件主动传入新的props,否则组件的 props永远保持不变。

非受控组件

React要编写一个非受控组件,可以使用ref来从Dom节点中获取表单数据,即为非受控组件

import React, { Component } from 'react'
export default class App extends Component {
    myusername = React.createRef()
  render() {
    return (
      <div>
            <h1>登录页</h1>
            <input type="text" ref = {this.myusername} value="lll"/>
            <button onClick={()=>{
                console.log(this.myusername.current.value);
            }}>登录</button>
            <button onClick={()=>{
                this.myusername.current.value = ""
            }}>重置</button>
      </div>
    )
  }
}

在该非受控组件中,input表单中的值无法改变,永远都是‘lll’,因为非受控组件将真实的数据储存在Dom节点中

受控组件

通过state状态来改变表单中的值,对于受控组件来说,输入的值始终由React的state驱动

import React, { Component } from 'react'
export default class App extends Component {
    state={
        myusername:"kerwin"
    }
    render() {
        return (
          <div>
                <h1>登录页</h1>
                <input type="text" value={this.state.myusername}
                 onChange={(evt)=>{
                                 console.log("onchange",evt.target.value);
                     this.setState({
                         myusername:evt.target.value
                     })
                }}/>
                <button onClick={()=>{
                    console.log(this.state.myusername);
                }}>登录</button>
                <button onClick={()=>{
                    this.setState({
                        myusername:""
                    })
                }}>重置</button>
          </div>
        )
      }
}

表单中的value值为state.myusername值,因此每次触发onChange绑定的事件改变state.myusername值,则表单中的value也随之改变,因此input表单中的值随着用户的输入而更新

希望对大家有所帮助,期待你们的支持✨✨✨



目录
相关文章
|
12天前
|
前端开发
React 中高阶组件的原理是什么?
React 中高阶组件的原理是什么?
86 57
|
12天前
|
前端开发
在 React 中使用高阶组件时,如何避免命名冲突?
在 React 中使用高阶组件时,如何避免命名冲突?
78 56
|
5天前
|
移动开发 前端开发 JavaScript
React音频播放列表组件:常见问题、易错点与解决方案
本文介绍了在React中实现音频播放列表时常见的挑战及解决方案。通过基础实现、常见问题分析和最佳实践,帮助开发者避免状态管理、生命周期控制和事件处理中的陷阱。关键点包括使用`useRef`操作音频元素、`useState`同步播放状态、全局状态管理防止多音频同时播放、以及通过`useEffect`清理资源。还提供了代码示例和跨浏览器兼容性处理方法,确保高效实现功能并减少调试时间。
69 30
|
3天前
|
编解码 前端开发 开发者
React 图片组件样式自定义:常见问题与解决方案
在 React 开发中,图片组件的样式自定义常因细节问题导致布局错乱、性能损耗或交互异常。本文系统梳理常见问题及解决方案,涵盖基础样式应用、响应式设计、加载状态与性能优化等,结合代码案例帮助开发者高效实现图片组件的样式控制。重点解决图片尺寸不匹配、边框阴影不一致、移动端显示模糊、加载失败处理及懒加载等问题,并总结易错点和最佳实践,助力开发者提升开发效率和用户体验。
33 22
|
8天前
|
移动开发 前端开发 UED
React 音频音量控制组件 Audio Volume Control
在现代Web应用中,音频播放功能不可或缺。React以其声明式编程和组件化开发模式,非常适合构建复杂的音频音量控制组件。本文介绍了如何使用HTML5 `&lt;audio&gt;`元素与React结合,实现直观的音量控制系统,并解决了常见问题如音量范围不合理、初始音量设置及性能优化等,帮助开发者打造优秀的音频播放器。
59 27
|
9天前
|
移动开发 前端开发 开发者
React 音频播放控制组件 Audio Controls
本文介绍了如何使用React构建音频播放控制组件,涵盖HTML5 `&lt;audio&gt;`标签和React组件化思想的基础知识。针对常见问题如播放状态管理、进度条更新不准确及跨浏览器兼容性,提供了详细的解决方案和代码示例。同时,还总结了易错点及避免方法,如确保音频加载完成再操作、处理音频错误等,帮助开发者实现稳定且功能强大的音频播放器。
43 11
|
8天前
|
移动开发 前端开发 UED
React 音频进度条组件 Audio Progress Bar
在现代Web开发中,音频播放功能不可或缺。使用React构建音频进度条组件,不仅能实现播放控制和拖动跳转,还能确保代码的可维护性和复用性。本文介绍了如何利用HTML5 `&lt;audio&gt;`标签的基础功能、解决获取音频时长和当前时间的问题、动态更新进度条样式,并避免常见错误如忘记移除事件监听器和忽略跨浏览器兼容性。通过这些方法,开发者可以打造高质量的音频播放器,提升用户体验。
40 6
|
4月前
|
前端开发 JavaScript 开发者
颠覆传统:React框架如何引领前端开发的革命性变革
【10月更文挑战第32天】本文以问答形式探讨了React框架的特性和应用。React是一款由Facebook推出的JavaScript库,以其虚拟DOM机制和组件化设计,成为构建高性能单页面应用的理想选择。文章介绍了如何开始一个React项目、组件化思想的体现、性能优化方法、表单处理及路由实现等内容,帮助开发者更好地理解和使用React。
130 9
|
5月前
|
前端开发
深入解析React Hooks:构建高效且可维护的前端应用
本文将带你走进React Hooks的世界,探索这一革新特性如何改变我们构建React组件的方式。通过分析Hooks的核心概念、使用方法和最佳实践,文章旨在帮助你充分利用Hooks来提高开发效率,编写更简洁、更可维护的前端代码。我们将通过实际代码示例,深入了解useState、useEffect等常用Hooks的内部工作原理,并探讨如何自定义Hooks以复用逻辑。
|
4月前
|
监控 前端开发 数据可视化
3D架构图软件 iCraft Editor 正式发布 @icraft/player-react 前端组件, 轻松嵌入3D架构图到您的项目,实现数字孪生
@icraft/player-react 是 iCraft Editor 推出的 React 组件库,旨在简化3D数字孪生场景的前端集成。它支持零配置快速接入、自定义插件、丰富的事件和方法、动画控制及实时数据接入,帮助开发者轻松实现3D场景与React项目的无缝融合。
309 8
3D架构图软件 iCraft Editor 正式发布 @icraft/player-react 前端组件, 轻松嵌入3D架构图到您的项目,实现数字孪生