React组件 -- Tabs封装

本文介绍了一种封装antd的Tab组件的方法。通过对antd的Tab组件的封装,可以让我们更加聚焦在每个页面的逻辑构造上,从而提高开发效率。

1. 首先,引入需要的依赖项和样式文件

javascript 复制代码
import './index.less';
import React, { useState, useEffect } from 'react';
import PageLayout from '../components/PageLayout';
import {getData} from '../utils/api/';
import { Tabs } from 'antd';
import Page1 from './Page1';
import Page2 from './Page2';
import Page3 from './Page3';
import Page4 from './Page4';
import PropTypes from 'prop-types';

以上代码段中,开始引入了必要的样式文件和依赖项。index.less用于添加组件特定样式。还引入了React相关的函数和组件,包括自定义的PageLayoutTabs以及Page1到Page4四个页面组件。最后,引入了PropTypes用于对属性进行类型检查。

2. 定义 ViewMgt 组件,接受一个名为 props 的参数

javascript 复制代码
export default function ViewMgt(props) {
  const [activeKey, setActiveKey] = useState('page1');
  const [allData, setAllData] = useState({
    'page1': null,
    'page2': null,
    'page3': null,
    'page4': null,
  });
  const [flag, setFlag] = useState(true);

  useEffect(() => {
    const { activeTab } = (props && props.location.state) || {};
    setActiveKey(activeTab || 'page1');

    getData().then(data => {
        setAllData({...data})
    })
  }, []);

  const forceUpdate(setFlag(!flag));

以上代码段中,定义了一个名为ViewMgt的函数组件,它接受一个名为props的参数。

在组件内部,使用了useStateuseEffect Hook。useState用于定义具有初始值'page1'的状态变量activeKey和对应的状态更新函数setActiveKeyuseEffect用于在组件挂载时根据props.location.state中的activeTab设置初始的选项卡活动状态。

3. 定义选项卡的配置数组

javascript 复制代码
const items = [
  {
    key: 'page1',
    label: 'Page1',
    component: <Page1 forceUpdate={forceUpdate} data={allData} />,
  },
  {
    key: 'page2',
    label: 'Page2',
    component: <Page2 forceUpdate={forceUpdate} data={allData} />,
  },
  {
    key: 'page3',
    label: 'Page3',
    component: <Page3 forceUpdate={forceUpdate} data={allData} />,
  },
  {
    key: 'page4',
    label: 'Page4',
    component: <Page4 forceUpdate={forceUpdate} data={allData} />,
  },
];

以上代码段中,定义了一个名为items的数组来配置选项卡。

数组中的每个对象分别代表一个选项卡,包含了keylabelcomponent属性。key是选项卡的键,label是选项卡的标签,component是对应的页面组件,通过JSX语法进行渲染。

4. 构造组件

javascript 复制代码
return (
  <PageLayout
    className="Your page's root classname."
    title="Your page's title."
    desc="Your page's description."
  >
    <Tabs id={'your-page-tabs'} activeKey={activeKey} onChange={setActiveKey}>
      {items.map(pane => (
        <TabPane tab={pane.label} key={pane.key}>
          <div className="your-page-pane">{pane.component}</div>
        </TabPane>
      ))}
    </Tabs>
  </PageLayout>
);

以上代码段中,返回了组件的 JSX 结构。

在此结构中,使用了PageLayout组件作为页面的布局容器,并传入了classNametitledesc作为属性。

Tabs组件中,设置了idactiveKeyonChange属性,activeKey使用了之前定义的activeKey状态变量,onChange使用了之前定义的setActiveKey状态更新函数。

Tabs组件内部,使用map方法遍历items数组,为每个选项卡渲染对应的TabPane组件。在TabPane组件中,渲染了选项卡的内容,通过pane.component来引用相应的页面组件。

5. 对传入的 props 进行类型检查

javascript 复制代码
ViewMgt.propTypes = {
  location: PropTypes.any,
};

propTypes中,指定了location属性的类型为any,这样可以确保在使用ViewMgt组件时传递的propslocation属性具有正确的类型。

相关推荐
热爱编程的小曾6 分钟前
sqli-labs靶场 less 8
前端·数据库·less
gongzemin17 分钟前
React 和 Vue3 在事件传递的区别
前端·vue.js·react.js
Apifox30 分钟前
如何在 Apifox 中通过 Runner 运行包含云端数据库连接配置的测试场景
前端·后端·ci/cd
-代号952735 分钟前
【JavaScript】十四、轮播图
javascript·css·css3
树上有只程序猿1 小时前
后端思维之高并发处理方案
前端
庸俗今天不摸鱼2 小时前
【万字总结】前端全方位性能优化指南(十)——自适应优化系统、遗传算法调参、Service Worker智能降级方案
前端·性能优化·webassembly
QTX187302 小时前
JavaScript 中的原型链与继承
开发语言·javascript·原型模式
黄毛火烧雪下2 小时前
React Context API 用于在组件树中共享全局状态
前端·javascript·react.js
Apifox2 小时前
如何在 Apifox 中通过 CLI 运行包含云端数据库连接配置的测试场景
前端·后端·程序员
一张假钞2 小时前
Firefox默认在新标签页打开收藏栏链接
前端·firefox