react-09-类组件-事件传参-条件布局-循环布局

简介: 类组件的一些常规操作,相当于在函数组件里面可以做的事情,我们在类组件里面也给实现一下

1. 前言


类组件的一些常规操作,相当于在函数组件里面可以做的事情,我们在类组件里面也给实现一下


2.传参 语法基础 2 种方式


2.1  用bind函数传参数


<li onClick={this.chooseHandle.bind(this,"react")}>react</li>


2.2 用一个中间函数转接一下


<li onClick={()=>{
                                    this.chooseHandle("小程序")
                             }}>小程序</li>


2.3 完整代码


class ToggleComponent extends React.Component{
            constructor(){
                super();
            }
            // ----自定义函数----
             chooseHandle (name){
                 console.log(name);
             }
             render() {
                return (
                        <div>
                         <ul>
                             <li onClick={this.chooseHandle.bind(this,"react")}>react</li>
                             <li onClick={()=>{
                                    this.chooseHandle("小程序")
                             }}>小程序</li>
                             <li onClick={this.chooseHandle}>vue</li>
                         </ul>
                        </div>
                    )
                };
        }



3. 条件布局


demo是简易的 登录注册界面 切换

3.1 条件布局 -1

先熟悉基础的语法逻辑 ,后续这些都可以单独写个组件

这个其实也是之前 状态切换的一个应用

解构赋值, 三目运算,常规使用

setState()的回调函数写法


class LoginControl extends React.Component {
        constructor() {
          super();
          this.state = {
            toggle: true
          };
          this.toggleHandler = this.toggleHandler.bind(this);
        }
        //   ---------自定义函数 ---------
        toggleHandler() {
          this.setState(oldState => {
            return {
              toggle: !oldState.toggle
            };
          });
        }
        render() {
          let { toggle } = this.state;
          return (
            <div>
              {toggle ? <h1>登录界面</h1> : <h1>注册界面</h1>}
              <button onClick={this.toggleHandler}> 点击切换界面</button>
            </div>
          );
        }
      }
      ReactDOM.render(<LoginControl />, box);


3.2 条件布局-2

主要是熟悉把这个 虚拟DOM 对象,当做变量来使用


render() {
          // if判断只能写到return上面
          let { toggle } = this.state;
          // 保存登录或者注册
          let layout = null;
          if (toggle) {
            layout = <h1>登录界面</h1>;
          } else {
            layout = <h1>注册界面</h1>;
          }
          return (
            <div>
              {layout}
              <button onClick={this.toggleHandler}> 点击切换界面</button>
            </div>
          );
        }



4. 循环布局使用


数组map 的使用 在 react里面非常常见,

因为map 不改变原数组,而且可以return一个新的数组

4.1  使用方式---1

key不要忘记

利用 react数组 会自动展开的特性


class ListItem extends React.Component {
        state = {
          numbers:["Vue3", "vite", "TS", "鸿蒙"]
        };
        render() {
          let { numbers } = this.state;
          let items = numbers.map(value => {
            return <li key={value}>{value}</li>;
          });
          return (
            <div>
              <ul>{items}</ul>
            </div>
          );
        }
      }
      ReactDOM.render(<ListItem />, box);


4.2  循环布局---2

js代码 写到 {}里面

map 遍历 直接返回 () 因为箭头函数 只有一行的话可以省略 return{}


return (
            <div>
              <ol>
                {
              numbers.map(value => (
                  <li key={value}>{value}</li>
                ))
          }
              </ol>
            </div>
          );


4.3  循环布局-3

上面的写法看不懂的话  看这个,


return (
            <div>
              <ul>{items}</ul>
              <br />
              <ol>
              {
                numbers.map(value=>{
                  return  <li key={value}>{value}</li>
                })
              }
              </ol>
            </div>
          );




相关文章
|
5天前
|
前端开发 Java API
React 进度条组件 ProgressBar 详解
本文介绍了如何在 React 中创建进度条组件,从基础实现到常见问题及解决方案,包括动态更新、状态管理、性能优化、高级动画效果和响应式设计等方面,帮助开发者构建高效且用户体验良好的进度条。
32 18
|
19天前
|
存储 前端开发 测试技术
React组件的最佳实践
React组件的最佳实践
|
18天前
|
前端开发 API 开发者
React 文件上传组件 File Upload
本文详细介绍了如何在 React 中实现文件上传组件,从基础的文件选择和上传到服务器,再到解决文件大小、类型限制、并发上传等问题,以及实现多文件上传、断点续传和文件预览等高级功能,帮助开发者高效构建可靠的应用。
47 12
|
13天前
|
存储 前端开发 JavaScript
React 表单输入组件 Input:常见问题、易错点及解决方案
本文介绍了在 React 中使用表单输入组件 `Input` 的基础概念,包括受控组件与非受控组件的区别及其优势。通过具体代码案例,详细探讨了创建受控组件、处理多个输入字段、输入验证和格式化的方法,并指出了常见易错点及避免方法,旨在提升表单的健壮性和用户体验。
25 4
|
20天前
|
前端开发 JavaScript API
React 文件下载组件 File Download
本文介绍了在React中实现文件下载组件的方法,包括使用`a`标签和JavaScript动态生成文件,解决了文件路径、文件类型、大文件下载及文件名乱码等问题,并展示了使用第三方库`file-saver`和生成CSV文件的高级用法。
31 6
|
17天前
|
前端开发 JavaScript API
React 文件下载组件:File Download
本文详细介绍了如何在React应用中实现文件下载组件,包括基本概念、实现步骤和代码示例。同时,探讨了常见问题如文件类型不匹配、文件名乱码等及其解决方法,旨在提升用户体验和代码可维护性。
34 2
|
21天前
|
存储 前端开发 JavaScript
React 文件上传组件 File Upload
本文介绍了如何在 React 中实现文件上传组件,包括基本的概念、实现步骤、常见问题及解决方案。通过 `&lt;input type=&quot;file&quot;&gt;` 元素选择文件,使用 `fetch` 发送请求,处理文件类型和大小限制,以及多文件上传和进度条显示等高级功能,帮助开发者构建高效、可靠的文件上传组件。
55 2
|
1月前
|
前端开发 JavaScript 开发者
颠覆传统:React框架如何引领前端开发的革命性变革
【10月更文挑战第32天】本文以问答形式探讨了React框架的特性和应用。React是一款由Facebook推出的JavaScript库,以其虚拟DOM机制和组件化设计,成为构建高性能单页面应用的理想选择。文章介绍了如何开始一个React项目、组件化思想的体现、性能优化方法、表单处理及路由实现等内容,帮助开发者更好地理解和使用React。
75 9
|
2月前
|
前端开发
深入解析React Hooks:构建高效且可维护的前端应用
本文将带你走进React Hooks的世界,探索这一革新特性如何改变我们构建React组件的方式。通过分析Hooks的核心概念、使用方法和最佳实践,文章旨在帮助你充分利用Hooks来提高开发效率,编写更简洁、更可维护的前端代码。我们将通过实际代码示例,深入了解useState、useEffect等常用Hooks的内部工作原理,并探讨如何自定义Hooks以复用逻辑。
|
22天前
|
监控 前端开发 数据可视化
3D架构图软件 iCraft Editor 正式发布 @icraft/player-react 前端组件, 轻松嵌入3D架构图到您的项目,实现数字孪生
@icraft/player-react 是 iCraft Editor 推出的 React 组件库,旨在简化3D数字孪生场景的前端集成。它支持零配置快速接入、自定义插件、丰富的事件和方法、动画控制及实时数据接入,帮助开发者轻松实现3D场景与React项目的无缝融合。
83 8
3D架构图软件 iCraft Editor 正式发布 @icraft/player-react 前端组件, 轻松嵌入3D架构图到您的项目,实现数字孪生