当前位置: 首页 > news >正文

react常用知识点

React是一个用于构建用户界面的JavaScript库。以下是React常用的知识点:

  1. 组件:React将用户界面分解成小而独立的组件,每个组件都有自己的状态和属性,并且可以通过组合这些组件来构建复杂的用户界面。

    // 函数组件示例
    function Welcome(props) {return <h1>Hello, {props.name}!</h1>;
    }// 类组件示例
    class Welcome extends React.Component {render() {return <h1>Hello, {this.props.name}!</h1>;}
    }
    

  2. JSX:JSX是一种类似HTML的语法扩展,它允许在JavaScript代码中编写类似XML的结构。使用JSX可以方便地创建React组件。

    // JSX示例
    const element = <h1>Hello, world!</h1>;
    

  3. 状态(State):React组件可以拥有自己的状态,状态是组件内部可变的数据。当状态发生改变时,React会自动重新渲染组件。

    // 状态示例
    class Counter extends React.Component {constructor(props) {super(props);this.state = { count: 0 };}render() {return (<div><p>Count: {this.state.count}</p><button onClick={() => this.setState({ count: this.state.count + 1 })}>Increment</button></div>);}
    }
    

  4. 属性(Props):组件可以接收来自父组件的属性,并根据属性的值进行渲染。属性是组件的只读数据,不应该在组件内部修改。

    // 属性示例
    function Welcome(props) {return <h1>Hello, {props.name}!</h1>;
    }const element = <Welcome name="Alice" />;
    

  5. 生命周期:React组件具有生命周期方法,在组件的不同阶段调用这些方法可以执行相应的操作,例如组件初始化、更新或卸载时。

    // 生命周期示例
    class ExampleComponent extends React.Component {componentDidMount() {console.log('Component did mount');}componentDidUpdate(prevProps, prevState) {console.log('Component did update');}componentWillUnmount() {console.log('Component will unmount');}render() {return <h1>Hello, world!</h1>;}
    }
    

  6. 事件处理:React组件可以响应用户的交互事件,例如点击、输入等。通过事件处理函数,可以对用户操作做出响应并更新组件状态或执行其他操作。

    // 事件处理示例
    class Button extends React.Component {handleClick() {console.log('Button clicked');}render() {return <button onClick={this.handleClick}>Click me</button>;}
    }
    

  7. 条件渲染:根据条件决定是否渲染特定的组件或内容。通过条件判断语句或三元表达式,可以在组件渲染过程中根据需要进行不同的渲染。

    // 条件渲染示例
    function Greeting(props) {if (props.isLoggedIn) {return <h1>Welcome back!</h1>;} else {return <h1>Please sign up.</h1>;}
    }const element = <Greeting isLoggedIn={false} />;
    

  8. 列表渲染:通过遍历数组或对象,将数据动态地渲染为列表。使用map函数可以方便地生成列表元素。

    // 列表渲染示例
    function NumberList(props) {const numbers = props.numbers;const listItems = numbers.map((number) => (<li key={number.toString()}>{number}</li>));return <ul>{listItems}</ul>;
    }const numbers = [1, 2, 3, 4, 5];
    const element = <NumberList numbers={numbers} />;
    

  9. 表单处理:React提供了一些用于处理表单的组件和方法,例如input、textarea、select等。可以通过这些组件获取用户输入的数据,并在组件内部进行处理。

    // 表单处理示例
    class NameForm extends React.Component {constructor(props) {super(props);this.state = { value: '' };}handleChange(event) {this.setState({ value: event.target.value });}handleSubmit(event) {event.preventDefault();console.log('Name submitted: ' + this.state.value);}render() {return (<form onSubmit={this.handleSubmit}><label>Name:<inputtype="text"value={this.state.value}onChange={this.handleChange}/></label>

  10. 组件通信:React组件之间可以通过属性传递数据和回调函数进行通信。父组件可以将数据作为属性传递给子组件,子组件可以通过调用父组件提供的回调函数来通知父组件发生了某些事件。

    // 组件通信示例
    class ParentComponent extends React.Component {constructor(props) {super(props);this.state = { message: '' };}handleMessageChange = (message) => {this.setState({ message });};render() {return (<div><ChildComponentmessage={this.state.message}onMessageChange={this.handleMessageChange}/></div>);}
    }class ChildComponent extends React.Component {handleChange = (event) => {this.props.onMessageChange(event.target.value);};render() {return (<div><inputtype="text"value={this.props.message}onChange={this.handleChange}/></div>);}
    }

以上是React的一些常用知识点,掌握了这些知识,可以更好地开发React应用程序。

http://www.lryc.cn/news/101837.html

相关文章:

  • iOS开发-QLPreviewController与UIDocumentInteractionController显示文档
  • 八、用 ChatGPT 帮助排查生产事故
  • WPF实战学习笔记25-首页汇总
  • FreeRTOS源码分析-7 消息队列
  • 机器学习深度学习——权重衰减
  • 【Linux】线程互斥 -- 互斥锁 | 死锁 | 线程安全
  • 【vue-pdf】PDF文件预览插件
  • Flink集群运行模式--Standalone运行模式
  • Spring整合JUnit实现单元测试
  • Spring Boot学习路线1
  • 管理类联考——写作——论说文——实战篇——标题篇
  • idea中设置maven本地仓库和自动下载依赖jar包
  • 前缀和差分
  • Golang GORM 模型定义
  • 微服务的各种边界在架构演进中的作用
  • 使用 docker-compose 一键部署多个 redis 实例
  • 14-测试分类
  • 打开域名跳转其他网站,官网被黑解决方案(Linux)
  • redis总结
  • 现代C++中的从头开始深度学习:激活函数
  • python怎么实现tcp和udp连接
  • java设计模式-观察者模式(jdk内置)
  • 秒级体验本地调试远程 k8s 中的服务
  • CV前沿方向:Visual Prompting 视觉提示工程下的范式
  • Redis五大基础类型解析
  • 在CSDN学Golang云原生(服务网格istio)
  • Golang 获取本地 IP 地址方法
  • 抖音seo短视频账号矩阵系统技术开发简述
  • 运维高级--shell脚本完成分库分表
  • Mysql 忘记密码怎么重置密码(详细步骤)