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属性具有正确的类型。

相关推荐
过期的H2O212 分钟前
【H2O2|全栈】关于CSS(4)CSS基础(四)
前端·css
纳尼亚awsl26 分钟前
无限滚动组件封装(vue+vant)
前端·javascript·vue.js
八了个戒31 分钟前
【TypeScript入坑】TypeScript 的复杂类型「Interface 接口、class类、Enum枚举、Generics泛型、类型断言」
开发语言·前端·javascript·面试·typescript
西瓜本瓜@33 分钟前
React + React Image支持图像的各种转换,如圆形、模糊等效果吗?
前端·react.js·前端框架
黄毛火烧雪下34 分钟前
React 的 useEffect 钩子,执行一些异步操作来加载基本信息
前端·chrome·react.js
蓝莓味柯基40 分钟前
React——点击事件函数调用问题
前端·javascript·react.js
资深前端之路41 分钟前
react jsx
前端·react.js·前端框架
cc蒲公英1 小时前
vue2中使用vue-office库预览pdf /docx/excel文件
前端·vue.js
一嘴一个橘子1 小时前
js 将二进制文件流,下载为excel文件
javascript
Sam90291 小时前
【Webpack--013】SourceMap源码映射设置
前端·webpack·node.js