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

相关推荐
啊哈一半醒几秒前
CSS 主流布局
前端·css·css布局·标准流 浮动 定位·flex grid 响应式布局
PHP武器库3 分钟前
ULUI:不止于按钮和菜单,一个专注于“业务组件”的纯 CSS 框架
前端·css
方也_arkling9 分钟前
Element Plus主题色定制
javascript·sass
电商API_1800790524712 分钟前
第三方淘宝商品详情 API 全维度调用指南:从技术对接到生产落地
java·大数据·前端·数据库·人工智能·网络爬虫
晓晓莺歌13 分钟前
vue3某一个路由切换,导致所有路由页面均变成空白页
前端·vue.js
2601_9498095931 分钟前
flutter_for_openharmony家庭相册app实战+我的Tab实现
java·javascript·flutter
Up九五小庞42 分钟前
开源埋点分析平台 ClkLog 本地部署 + Web JS 埋点测试实战--九五小庞
前端·javascript·开源
摘星编程1 小时前
React Native + OpenHarmony:UniversalLink通用链接
javascript·react native·react.js
qq_177767371 小时前
React Native鸿蒙跨平台数据使用监控应用技术,通过setInterval每5秒更新一次数据使用情况和套餐使用情况,模拟了真实应用中的数据监控场景
开发语言·前端·javascript·react native·react.js·ecmascript·harmonyos
烬头88211 小时前
React Native鸿蒙跨平台应用实现了onCategoryPress等核心函数,用于处理用户交互和状态更新,通过计算已支出和剩余预算
前端·javascript·react native·react.js·ecmascript·交互·harmonyos