• react使用Material UI实现类似淘宝tab居中切换效果


    Material UI 简介

    Material UI is an open-source React component library that implements Google's Material Design.

    It includes a comprehensive collection of prebuilt components that are ready for use in production right out of the box.

    Material UI is beautiful by design and features a suite of customization options that make it easy to implement your own custom design system on top of our components.

    Material UI是一个开源的React组件库,实现了Google的材质设计。


    它包括一个全面的预构建组件集合,可直接用于生产。


    Material UI设计美观,具有一套定制选项,可在我们的组件之上轻松实现您自己的定制设计系统。

    Advantages of Material UI

    • Ship faster: thousands of open-source contributors have poured countless hours into these components. Focus on your core business logic instead of reinventing the wheel—we've got your UI covered.
    • Beautiful by default: we're meticulous about our implementation of Material Design, ensuring that every Material UI component meets the highest standards of form and function, but diverge from the official spec where necessary to provide multiple great options.
    • Customizability: the library includes an extensive set of intuitive customizability features. The templates in our store demonstrate how far you can go with customization.
    • Cross-team collaboration: Material UI's intuitive developer experience reduces the barrier to entry for back-end developers and less technical designers, empowering teams to collaborate more effectively. The design kits streamline your workflow and boost consistency between designers and developers.
    • Trusted by thousands of organizations: Material UI has the largest UI community in the React ecosystem. It's almost as old as React itself—its history stretches back to 2014—and we're in this for the long haul. You can count on community's support for years to come (e.g. Stack Overflow)

    ​材料UI的优势

    发布速度更快:成千上万的开源贡献者已经为这些组件投入了无数的时间。关注您的核心业务逻辑,而不是重新发明轮子,我们已经涵盖了您的UI。

    默认情况下很漂亮:我们对材料设计的实现非常仔细,确保每个材料UI组件都符合形式和功能的最高标准,但在必要时偏离官方规范,以提供多个很棒的选项。

    可定制性:该库包括一系列直观的可定制功能。我们商店中的模板展示了您可以进行定制的程度。

    跨团队协作:Material UI直观的开发人员体验减少了后端开发人员和技术较少的设计师进入的障碍,使团队能够更有效地协作。设计套件简化了您的工作流程,提高了设计人员和开发人员之间的一致性。

    受到数千家组织的信任:Material UI在React生态系统中拥有最大的UI社区。它的历史可以追溯到2014年,我们将长期参与其中。您可以在未来几年依靠社区的支持(例如,堆栈溢出)。

     



    Index.js:

    1. import React, { Suspense } from 'react'
    2. import { connect } from 'react-redux'
    3. import { withRouter, Switch } from 'react-router-dom'
    4. import { Tabs, Tab, Box } from '@mui/material'
    5. import useList from './useList'
    6. import { Loading } from '../../../../components/light'
    7. import { SinglePageHeader } from '../../../../components/light'
    8. import './index.css'
    9. function Index(props) {
    10. // eslint-disable-next-line
    11. const { routeDom, filterRouteArr, tabsValue, handleTabsChange } = useList(props)
    12. return (
    13. <div>
    14. <div className="m-single-wrap">
    15. <div className="m-single-inner">
    16. <SinglePageHeader>SinglePageHeader>
    17. <Box sx={{ bgcolor: 'background.paper' }}>
    18. <Tabs
    19. value={tabsValue}
    20. onChange={handleTabsChange}
    21. variant="scrollable"
    22. scrollButtons={false}
    23. // allowScrollButtonsMobile={true}
    24. // centered={true}
    25. className="m-mui-tabs"
    26. >
    27. {filterRouteArr.map((item, index) => (<Tab key={index} id={`m-tab-${index}`} label={item.title} />))}
    28. Tabs>
    29. Box>
    30. <Suspense fallback={<Loading isLazyLoading={true}>Loading>}>
    31. <Switch>{routeDom}Switch>
    32. Suspense>
    33. div>
    34. div>
    35. div>
    36. )
    37. }
    38. const mapStateToProps = (state) => {
    39. return {
    40. collapsed: state.getIn(['light', 'collapsed']),
    41. }
    42. }
    43. const mapDispatchToProps = (dispatch) => {
    44. return {
    45. onSetState(key, value) {
    46. dispatch({ type: 'SET_LIGHT_STATE', key, value })
    47. },
    48. onDispatch(action) {
    49. dispatch(action)
    50. },
    51. }
    52. }
    53. export default connect(mapStateToProps, mapDispatchToProps)(withRouter(Index))

    useList.js:

    1. import { useState, useEffect, lazy } from 'react'
    2. import { Route, Redirect } from 'react-router-dom'
    3. import Api from '../../../../api'
    4. export default function useList(props) {
    5. // eslint-disable-next-line
    6. const [groupButton1, setGroupButton1] = useState([])
    7. const [routeDom, setRouteDom] = useState()
    8. const [filterRouteArr, setFilterRouteArr] = useState([])
    9. const [tabsValue, setTabsValue] = useState(0)
    10. const handleTabsChange = (event, newValue) => {
    11. setTabsValue(newValue)
    12. document
    13. .getElementById(`m-tab-${newValue}`)
    14. .scrollIntoView({ behavior: 'smooth', inline: 'center' })
    15. }
    16. useEffect(() => {
    17. const routeArr = [
    18. {
    19. title: '消息私信',
    20. path: '/h5/single/me/privateMessage',
    21. component: lazy(() => import('../../single/me/empty/Index')),
    22. },
    23. {
    24. title: '点赞',
    25. path: '/h5/single/me/like',
    26. component: lazy(() => import('../../single/me/empty/Index')),
    27. },
    28. {
    29. title: '收藏',
    30. path: '/h5/single/me/collect',
    31. component: lazy(() => import('../../single/me/collect/Index')),
    32. },
    33. {
    34. title: '浏览历史',
    35. path: '/h5/single/me/history',
    36. component: lazy(() => import('../../single/me/empty/Index')),
    37. },
    38. {
    39. title: '兑换',
    40. path: '/h5/single/me/exchange',
    41. component: lazy(() => import('../../single/me/exchange/Index')),
    42. },
    43. ]
    44. const filterRouteArr = routeArr
    45. .filter(
    46. (item) =>
    47. groupButton1.findIndex(
    48. (groupButton1Item) => groupButton1Item.path === item.path
    49. ) >= 0
    50. )
    51. const routeDom = filterRouteArr
    52. .map((item) => (
    53. <Route
    54. key={item.path}
    55. path={item.path}
    56. component={item.component}
    57. >Route>
    58. ))
    59. if (routeDom.length > 0) {
    60. routeDom.push(
    61. <Redirect key={'redirect'} from="*" to="/404" exact>Redirect>
    62. )
    63. }
    64. setRouteDom(routeDom)
    65. setFilterRouteArr(filterRouteArr)
    66. }, [groupButton1])
    67. useEffect(() => {
    68. Api.h5.configGetMeData().then((res) => {
    69. if (res.code === 200) {
    70. setGroupButton1(res.data.me.groupButton1)
    71. }
    72. })
    73. // eslint-disable-next-line
    74. }, [])
    75. return {
    76. routeDom,
    77. filterRouteArr,
    78. tabsValue,
    79. handleTabsChange,
    80. }
    81. }

    css:

    1. .m-mui-tabs .Mui-selected{color: #f04142!important;}
    2. .m-mui-tabs .css-1aquho2-MuiTabs-indicator{background-color: #f04142!important;}

  • 相关阅读:
    Stereo R-CNN based 3D Object Detection for Autonomous Driving
    项目 验证码的实现思路
    SpringMVC默认3个HandlerMapping和4个HandlerAdapter
    Mysql多表设计
    D. Constant Palindrome Sum(差分)
    FL Studio All Plugins Edition2024中文完整版Win/Mac
    2023-9-10 集合-Nim游戏
    key值的应用场景
    树的存储结构以及树,二叉树,森林之间的转换
    【Java 解析全国详细地址】Java 利用正则表达式完美解析全国省市区地址
  • 原文地址:https://blog.csdn.net/xutongbao/article/details/126666455