React-组件和props

1、类组件

javascript 复制代码
import React from 'react';
class ClassApp extends React.Component {
    constructor(props) {
        super(props);
        this.state={};
    }
    render() {
        return (
            <div>
                <h1>这是一个类组件</h1>
                <p>接收父组件传过来的值:{this.props.name}</p>
            </div>
        );
    }
}
export default ClassApp;

2、函数组件

javascript 复制代码
import React from 'react';
function FuncApp(props) {
    return (
        <div>
            <h1>我是函数组件</h1>
            <h2>接收父组件传过来的值:{props.name}</h2>
        </div>
    );
}

3、组件样式控制

javascript 复制代码
import './index.css';
function FuncApp(props) {
    return (
        <div>
            <h1 style={{ color: 'red', fontSize: 25 }}>我是函数组件</h1>
            <h2 className='info-box'>接收父组件传过来的值:{props.name}</h2>
        </div>
    );
}

// index.css
.info-box {
    color: skyblue;
    font-size: 25px;
}

4、React表单组件

React中的表单组件大致可分为两类:

  • 受控组件: 一般涉及到表单元素时我们才会使用这种分类方法。受控组件的值由props或state传入,用户在元素上交互或输入内容会引起应用state的改变。在state改变之后重新渲染组件,我们才能在页面中看到元素中值的变化,假如组件没有绑定事件处理函数改变state,用户的输入是不会起到任何效果的,这也就是"受控"的含义所在。
  • **非受控组件:**类似于传统的DOM表单控件,用户输入不会直接引起应用state的变化,我们也不会直接为非受控组件传入值。想要获取非受控组件,我们需要使用一个特殊的ref属性,同样也可以使用defaultValue属性来为其指定一次性的默认值。
javascript 复制代码
//受控组件
this.state = {
    value: "默认值"
}
change(event) {
    this.setState({value: event.target.value})
}
<div>
    <input type="text" value={this.state.value} onChange={this.change.bind(this)} />
    <p> {this.state.value} </p>
</div>
 
// hooks写法
import { useState } from "react";
function App() {
  const [name, setName] = useState('')
  return (
    <div className="App">
      <input type="text" value={name} onChange={(e) => setName(e.target.value)} />
    </div>
  );
}
export default App;
 
//非受控组件
<input type="text" defaultValue="hello!"/>

5、React获取dom元素

在react中操作dom,可以使用useRef钩子函数

(1)使用useRef创建ref对象,并于JSX绑定

javascript 复制代码
import { useRef } from "react";
function App() {
  const inputRef = useRef(null)
  return (
    <div className="App">
      <input type="text" ref={inputRef} />
      <button onClick={showDom}>显示dom</button>
    </div>
  );
}
export default App;

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

javascript 复制代码
const showDom = () => {
    console.log(inputRef.current);
}

6、props

(1)定义和使用props

react中的每一个组件,都包含有一个属性(props),属性主要是从父组件传递给子组件的

javascript 复制代码
// 父组件
function App() {
  const name = '张三'
  return (
    <div className="App">
      <Son name={name} />
    </div>
  );
}

// 子组件
function Son(props) {
  return (
    <div>{ props.name }</div>
  )
}

(2)特殊的prop children(类似于Vue的插槽)

当我们把内容嵌套在子组件标签中时,父组件会自动在名为children的prop属性中接收该内容

javascript 复制代码
// 父组件
function App() {
  const name = '张三'
  return (
    <div className="App">
      <Son name={name}>
        <span>hello</span>
      </Son>
    </div>
  );
}

// 子组件
function Son(props) {
  return (
    <div>{ props.children }--{ props.name}</div>
  )
}
相关推荐
BillKu1 小时前
Vue3 Element Plus 对话框加载实现
javascript·vue.js·elementui
郝YH是人间理想2 小时前
系统架构设计师案例分析题——web篇
前端·软件工程
Evaporator Core2 小时前
深入探索:Core Web Vitals 进阶优化与新兴指标
前端·windows
初遇你时动了情2 小时前
html js 原生实现web组件、web公共组件、template模版插槽
前端·javascript·html
QQ2740287562 小时前
Soundness Gitpod 部署教程
linux·运维·服务器·前端·chrome·web3
前端小崔3 小时前
从零开始学习three.js(18):一文详解three.js中的着色器Shader
前端·javascript·学习·3d·webgl·数据可视化·着色器
哎呦你好3 小时前
HTML 表格与div深度解析区别及常见误区
前端·html
运维@小兵3 小时前
vue配置子路由,实现点击左侧菜单,内容区域显示不同的内容
前端·javascript·vue.js
koiy.cc3 小时前
记录:echarts实现tooltip的某个数据常显和恢复
前端·echarts
一只专注api接口开发的技术猿4 小时前
企业级电商数据对接:1688 商品详情 API 接口开发与优化实践
大数据·前端·爬虫