React手寫tab切換問題

父文件
import React, { useState } from 'react';
// import Module1 from './Module1';
// import Module2 from './Module2';
// import Module3 from './Module3';
// import Module4 from './Module4';
import HeaderTtabs, { tagType } from '@/components/Task/Tree/Common/component/TabsContent/ListContent/HeadTabs';
import { divide } from 'lodash';
export default function (props: any) {
const tabsList: tagType[] = [
{ name: 'xxx況' },
{ name: '培育xxxxx', disabled: false },
{ name: '關(guān)xxxx', disabled: false },
{ name: '科xxxx', disabled: false },
{ name: '人xxxx', disabled: false },
];
const [checkedTag, setCheckedTag] = useState(tabsList[0])
return (<div>
<HeaderTtabs tabsList={tabsList} checkedTag={checkedTag} setCheckedMenu={(tab) => setCheckedTag(tab)} />
<div className={`pt5 px20 pb20`}>
{checkedTag.name === tabsList[0].name && <div>11</div>}
{checkedTag.name === tabsList[1].name && <div>22</div>}
{checkedTag.name === tabsList[2].name && <div>33</div>}
{checkedTag.name === tabsList[3].name && <div>44</div>}
{checkedTag.name === tabsList[4].name && <div>55</div>}
{/* {checkedTag.name === tabsList[0].name && <Module1 />}
{checkedTag.name === tabsList[1].name && <Module2 />}
{checkedTag.name === tabsList[2].name && <Module3 />}
{checkedTag.name === tabsList[3].name && <Module4 />} */}
</div>
</div>);
}
子文件
import style from './index.scss';
import React from 'react';
import { message } from 'antd';
// 標(biāo)簽類型
export type tagType = {
name: string, // 標(biāo)簽名稱,唯一
disabled?: boolean // 是否禁用
}
/**
* 子頁面 tab 欄
* @param props
*/
export default function(props: {
tabsList: tagType[], // 標(biāo)簽列表
checkedTag: tagType, // 當(dāng)前選中的標(biāo)簽
setCheckedMenu: (menu: tagType) => void // 標(biāo)簽點(diǎn)擊回調(diào)
}) {
const {tabsList, checkedTag, setCheckedMenu} = props
const setCheck = (menu: tagType) => {
if (menu.disabled) {
message.warning('功能暫未開放');
return
}
setCheckedMenu(menu)
}
return (<div className={`${style.tag_area} ${style.epidemic_area}`}>
{
tabsList.map((item) => (
<div className={`${style.tag} ${checkedTag.name === item.name ? style.checked : ''} ${style.epidemic}`} key={item.name} onClick={() => setCheck(item)}>
{item.name}
</div>
))
}
</div>)
}
子文件-tab樣式:

.tag_area {
display: flex;
align-items: center;
justify-content: center;
margin-top: -20px;
background-color: #fff;
margin-bottom: 20px;
@media only screen and (max-width: 768px) {
& {
margin-top: 10px;
}
}
}
.tag {
// flex: 1;
// margin: 0 15px;
min-width: 130px;
padding: 10px;
display: flex;
align-items: center;
justify-content: center;
background-color: #fff;
height: 50px;
color: #333;
cursor: pointer;
transition: .3s all;
// box-shadow: 5px 3px 4px #999;
font-size: 18px;
// border-radius: 10px;
border-radius: 6px 6px 0px 0px;
@media only screen and (max-width: 768px) {
& {
font-size: 14px;
margin: 0 5px;
min-height: 30px;
text-align: center;
padding: 5px;
}
}
&.checked {
color: #fff;
background-color: #1E9FFF;
}
&:hover {
color: #fff;
background-color: #1E9FFF;
}
}
// 浙里防疫 四個tab樣式
.epidemic_area{
justify-content: left;
margin: 10px 20px;
padding:10px;
}
.epidemic{
margin:0 10px;
width: 200px;
background: rgba(20, 146, 255, 0.1);
border: 1px solid #1492FF;
box-sizing: border-box;
border-radius: 4px;
height: 44px;
}
到此這篇關(guān)于React手寫tab切換的文章就介紹到這了,更多相關(guān)React tab切換內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
react-native 封裝視頻播放器react-native-video的使用
本文主要介紹了react-native 封裝視頻播放器react-native-video的使用,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-01-01
ReactHook使用useState更新變量后,如何拿到變量更新后的值
這篇文章主要介紹了ReactHook使用useState更新變量后,如何拿到變量更新后的值問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-03-03
React入門教程之Hello World以及環(huán)境搭建詳解
Facebook 為了開發(fā)一套更好更適合自己的JavaScript MVC 框架,所以產(chǎn)生了react。后來反響很好,所以于2013年5月開源。下面這篇文章主要給大家介紹了關(guān)于React入門教程之Hello World以及環(huán)境搭建的相關(guān)資料,需要的朋友可以參考借鑒。2017-07-07
詳解關(guān)于react-redux中的connect用法介紹及原理解析
本篇文章主要介紹了詳解關(guān)于react-redux中的connect用法介紹及原理解析,非常具有實用價值,需要的朋友可以參考下2017-09-09
淺析JS中什么是自定義react數(shù)據(jù)驗證組件
我們在做前端表單提交時,經(jīng)常會遇到要對表單中的數(shù)據(jù)進(jìn)行校驗的問題。這篇文章主要介紹了js中什么是自定義react數(shù)據(jù)驗證組件,需要的朋友可以參考下2018-10-10
react ant Design手動設(shè)置表單的值操作
這篇文章主要介紹了react ant Design手動設(shè)置表單的值操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-10-10

