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

相关推荐
喵叔哟8 分钟前
重构代码之取消临时字段
java·前端·重构
还是大剑师兰特1 小时前
D3的竞品有哪些,D3的优势,D3和echarts的对比
前端·javascript·echarts
王解1 小时前
【深度解析】CSS工程化全攻略(1)
前端·css
一只小白菜~1 小时前
web浏览器环境下使用window.open()打开PDF文件不是预览,而是下载文件?
前端·javascript·pdf·windowopen预览pdf
方才coding1 小时前
1小时构建Vue3知识体系之vue的生命周期函数
前端·javascript·vue.js
阿征学IT1 小时前
vue过滤器初步使用
前端·javascript·vue.js
王哲晓1 小时前
第四十五章 Vue之Vuex模块化创建(module)
前端·javascript·vue.js
丶21361 小时前
【WEB】深入理解 CORS(跨域资源共享):原理、配置与常见问题
前端·架构·web
发现你走远了1 小时前
『VUE』25. 组件事件与v-model(详细图文注释)
前端·javascript·vue.js
Mr.咕咕1 小时前
Django 搭建数据管理web——商品管理
前端·python·django