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>
          );




相关文章
|
30天前
|
缓存 前端开发 JavaScript
React Hooks深度解析与最佳实践:提升函数组件能力的终极指南
🌟蒋星熠Jaxonic,前端探索者。专注React Hooks深度实践,从原理到实战,分享状态管理、性能优化与自定义Hook精髓。助力开发者掌握函数组件的无限可能,共赴技术星辰大海!
React Hooks深度解析与最佳实践:提升函数组件能力的终极指南
|
6月前
|
缓存 前端开发 数据安全/隐私保护
如何使用组合组件和高阶组件实现复杂的 React 应用程序?
如何使用组合组件和高阶组件实现复杂的 React 应用程序?
252 68
|
6月前
|
缓存 前端开发 Java
在 React 中,组合组件和高阶组件在性能方面有何区别?
在 React 中,组合组件和高阶组件在性能方面有何区别?
229 67
|
6月前
|
前端开发 JavaScript 安全
除了高阶组件和render props,还有哪些在 React 中实现代码复用的方法?
除了高阶组件和render props,还有哪些在 React 中实现代码复用的方法?
252 62
|
9月前
|
移动开发 前端开发 API
React 音频播放器组件 Audio Player
本文介绍如何使用React创建音频播放器组件,涵盖核心功能如播放/暂停、进度条、音量控制和时间显示。通过HTML5 `&lt;audio&gt;` 元素和React的声明式状态管理,实现交互式音频播放。常见问题包括控件不响应、进度条无法更新和音量控制失灵,并提供解决方案。此外,还讨论了浏览器兼容性、异步错误处理和性能优化等易错点及避免方法。
659 123
|
8月前
|
前端开发 JavaScript
除了使用Route组件,React Router还有其他方式处理404错误页面吗
除了使用Route组件,React Router还有其他方式处理404错误页面吗
218 58
|
8月前
|
前端开发
React 中高阶组件的原理是什么?
React 中高阶组件的原理是什么?
203 57
|
8月前
|
前端开发 开发者
除了函数组件和类组件,React 还有其他创建组件的方式吗?
除了函数组件和类组件,React 还有其他创建组件的方式吗?
169 57
|
8月前
|
前端开发
如何在React Router中定义404错误页面组件?
如何在React Router中定义404错误页面组件?
184 57
|
8月前
|
前端开发
在 React 中使用高阶组件时,如何避免命名冲突?
在 React 中使用高阶组件时,如何避免命名冲突?
184 56
下一篇
开通oss服务