react 组件之组件的属性

简介: react 组件分为两种组件(由于本人会ts(typescript),所以后面的列子都是基于typescript来进行组件编写)

含义: 组件是包含内容(html),样式(css)和功能(js)的ui单元


分类


react 组件分为两种组件(由于本人会ts(typescript),所以后面的列子都是基于typescript来进行组件编写)


  • 函数式组件
  • 类组件


函数式组件


返回一个React元素


代码格式例如:


import React from 'react'
export default function MyFuncComp() {
  return (
    <div>
      我是函数式组件,// 这里面需要可以写该组件对于的css, js 和 html等,但是建议使用jsx
    </div>
  )
}


使用方式:


在需要使用的地方,import 该组件,然后在对应的位置中使用即可,但是这里有两种使用方式:


  • 直接函数使用:


20210212094154606.png


  • 通过组件的方式使用:


20210212094305645.png


效果


20210212094337884.png


类组件


必须继承React.Component


必须提供render函数,用于渲染组件


样例:


import React, { Component } from 'react'
export default class MyClassComp extends Component {
  render() {
    return (
      <div>
        我是类组件
      </div>
    )
  }
}


使用方式


和上面的函数式组件一样的,都是两种方式


注意事项:


  • react 组件导出的函数式组件或者类组件命名必须大写(大驼峰命名),原因,我们在使用组件的时候,如果使用标签的方式来进行使用,如果不是大驼峰的方式命名的话,在使用用会报错:


20210212095732802.png

20210212095924150.png


  • 使用组件的方式,尽量使用 标签的方式,原因: 使用标签的方式方便 react devtools 来进行调试,如:


20210212101702859.png

2021021210163826.png


函数调用方式:


20210212101809378.png

20210212101917925.png


组件传参


函数组件


对于函数组件,属性会作为一个对象的属性,传递给函数的第一个参数


样例:


// MyFuncComp.tsx 组件内容
import React from 'react'
interface MyFuncCompProps{
  // 测试数据
  num: number
}
export default function MyFuncComp(props:MyFuncCompProps) {
  return (
    <div>
      我是函数式组件,传递的数字{props.num}
    </div>
  )
}
// main.tsx 中调用
import React from 'react'
import ReactDOM from 'react-dom'
import MyFuncComp from './pro/comp/MyFuncComp'
ReactDOM.render(
  <div>
     <MyFuncComp num={1} /> // 可以多次调用达到复用
     <MyFuncComp num={2} /> // 进行传参
  </div>
 ,
  document.getElementById('root')
)


效果:


20210212103237726.png


类组件


对于类组件,属性会作为一个对象的属性,传递给构造函数的参数,(这一步操作,react 会默认自动完成)


样例


// MyClassComp.tsx 文件内容
import React, { Component } from 'react'
interface MyFuncCompProps {
  // 测试数据
  num: number
}
export default class MyClassComp extends Component<MyFuncCompProps> { // MyFuncCompProps 这个地方对组件属性进行限制
  render() {
    return (
      <div>
        我是类组件,传过来的数字是:{this.props.num}
      </div>
    )
  }
}
// main.tsx 中调用
import React from 'react'
import ReactDOM from 'react-dom'
import MyClassComp from './pro/comp/MyClassComp'
ReactDOM.render(
  <div>
     <MyClassComp num={1} /> //多次调用
     <MyClassComp num={2} /> // 传参方式是一样,参数的类型可以是任意的,只要接口约定好就行
  </div>
 ,
  document.getElementById('root')
)


效果


20210212105258176.png


注意:组件的属性,传递的参数应该使用``小驼峰命名法,参数理论上可以是任何值,包括react 创建的虚拟dom


组件无法改变自身的属性。


之前学习的React元素,div、li 基本上的html标签,本质上,就是一个组件(内置组件)


React中的哲学:数据属于谁,谁才有权力改动


React中的数据,自顶而下流动, 单向数据流


组件传递一个jsx 对象


通过上面我们知道了,组件可以传递任意的参数,但是如果我想在组件里面传递一个jsx对象呢?


两种方式:


第一种是直接通过属性的方式来进行传递,


例如:


import React, { Component } from 'react'
interface MyFuncCompProps {
  // 测试数据
  html: JSX.Element
}
export default class MyClassComp extends Component<MyFuncCompProps> {
  render() {
    return (
      <div>
        我是类组件,传过内容是:
        {this.props.html}
      </div>
    )
  }
}
// main.tsx 中调用
import React from 'react'
import ReactDOM from 'react-dom'
import MyClassComp from './pro/compProp/MyClassComp'
ReactDOM.render(
  <div>
     <MyClassComp html={<h1> 第一个标签</h1>} /> 
     <MyClassComp html={<h2> 第二个标签</h2>} /> 
  </div>
 ,
  document.getElementById('root'))


效果:


20210222105720160.png


第二种是直接通过子标签的形式


20210222110209474.png

20210222110234554.png


结果:


20210222110301813.png


> 如果是单个子节点可以使用自带的children语法糖,如果是多个,还是需要使用属性的方式来进行传参。

相关文章
|
27天前
|
前端开发 UED 索引
React 图片灯箱组件 Image Lightbox
图片灯箱组件是一种常见的Web交互模式,用户点击缩略图后弹出全屏窗口展示大图,并提供导航功能。本文介绍了基于React框架的图片灯箱组件开发,涵盖初始化状态管理、图片加载与预加载、键盘和鼠标事件处理等常见问题及解决方案。通过`useState`和`useEffect`钩子管理状态,使用懒加载和预加载优化性能,确保流畅的用户体验。代码案例展示了组件的基本功能实现,包括打开/关闭灯箱、切换图片及键盘操作。
127 80
|
11天前
|
移动开发 前端开发 JavaScript
React 视频播放控制组件 Video Controls
本文介绍了如何使用 React 构建视频播放控制组件(Video Controls),涵盖基本概念、创建步骤和常见问题解决。首先,通过 HTML5 `&lt;video&gt;` 标签和 React 组件化思想,实现播放/暂停按钮和进度条等基础功能。接着,详细讲解了初始化项目、构建 `VideoControls` 组件及与主应用的集成方法。最后,针对视频无法播放、控制器状态不同步、进度条卡顿和音量控制失效等问题提供了具体解决方案,并介绍了全屏播放和自定义样式等进阶功能。希望这些内容能帮助你在实际项目中更好地实现和优化视频播放功能。
83 40
|
26天前
|
移动开发 前端开发 JavaScript
React 视频播放器组件:Video Player
本文介绍了如何使用 React 和 HTML5 `&lt;video&gt;` 标签构建自定义视频播放器组件。首先,通过创建基础的 React 项目和 VideoPlayer 组件,实现了基本的播放、暂停功能。接着,探讨了常见问题如视频加载失败、控制条样式不一致、性能优化不足及状态管理混乱,并提供了相应的解决方案。最后,总结了构建高效视频播放器的关键要点,帮助开发者应对实际开发中的挑战。
110 27
|
29天前
|
前端开发 JavaScript API
React 图片放大组件 Image Zoom
本文介绍如何使用React创建图片放大组件(Image Zoom),提升用户体验。组件通过鼠标悬停或点击触发放大效果,利用`useState`管理状态,CSS实现视觉效果。常见问题包括图片失真、性能下降和移动端支持,分别可通过高质量图片源、优化事件处理和添加触摸事件解决。易错点涉及状态管理混乱、样式冲突和过多事件绑定,建议使用上下文API、CSS模块及优化事件绑定逻辑。高级功能扩展如多张图片支持和自定义放大区域进一步丰富了组件的实用性。
58 25
|
25天前
|
存储 编解码 前端开发
React 视频上传组件 Video Upload
随着互联网的发展,视频内容在网站和应用中愈发重要。本文探讨如何使用React构建高效、可靠的视频上传组件,涵盖基础概念、常见问题及解决方案。通过React的虚拟DOM和组件化开发模式,实现文件选择、进度显示、格式验证等功能,并解决跨域请求、并发上传等易错点。提供完整代码案例,确保用户能顺畅上传视频。
128 92
|
30天前
|
移动开发 前端开发 JavaScript
React 图片裁剪组件 Image Cropper
本文介绍了在React中实现图片裁剪功能的方法,涵盖基础知识、常见问题及解决方案。首先,通过第三方库如`react-image-crop`或`cropperjs-react`可轻松实现图片裁剪。接着,针对性能和兼容性问题,提供了优化图片加载、处理裁剪区域响应慢、解决浏览器差异等方案。最后,通过代码案例详细解释了如何创建一个基本的图片裁剪组件,并提出了优化建议,如使用`React.memo`、添加样式支持及处理大图片预览,帮助开发者避免常见错误并提升用户体验。
116 67
|
6天前
|
移动开发 前端开发 UED
React 音频预览组件:Audio Preview
本文介绍如何使用 React 构建音频预览组件,涵盖基础实现、常见问题及解决方案。通过 HTML5 `&lt;audio&gt;` 标签和 React 状态管理,实现播放控制。解决文件路径、浏览器兼容性等问题,并优化性能,避免状态不同步和内存泄漏,提升用户体验。
54 22
|
2月前
|
前端开发 UED 开发者
React 悬浮按钮组件 FloatingActionButton
悬浮按钮(FAB)是常见的UI元素,用于提供突出的操作。本文介绍如何在React中使用Material-UI创建美观的FAB组件,涵盖基本概念、实现方法及常见问题解决。通过代码示例和优化技巧,帮助开发者提升用户体验,确保按钮位置、颜色、交互反馈等方面的表现,同时避免无障碍性和性能问题。
134 80
|
1天前
|
移动开发 前端开发 JavaScript
React 视频播放控制组件 Video Controls
本文深入探讨了如何使用React创建功能丰富的视频播放控制组件(Video Controls)。首先介绍了React与HTML5 `&lt;video&gt;` 标签的基础知识,展示了如何通过状态管理和事件处理实现自定义控件。接着分析了常见问题如视频加载失败、控件样式不一致、状态管理混乱和性能问题,并提供了相应的解决方案。最后通过完整代码案例详细解释了播放、暂停、进度条和音量控制的实现方法,帮助开发者在React中构建高质量的视频播放组件。
36 17
|
8天前
|
移动开发 前端开发 UED
React 音频播放器组件 Audio Player
本文介绍如何使用React创建功能丰富的音频播放器组件。基于HTML5 `&lt;audio&gt;` 标签,结合React的状态管理和事件处理,实现播放、暂停、进度和音量控制等功能。通过代码示例展示基本实现,并探讨常见问题如自动播放限制、进度条不更新、文件加载失败及多实例冲突的解决方案。同时,避免易错点如忽略生命周期管理、错误处理和性能优化,确保高效开发与良好用户体验。
62 23