欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Taro?React自定義TabBar使用useContext解決底部選中異常

 更新時間:2023年08月31日 11:57:52   作者:故意避開  
這篇文章主要為大家介紹了Taro?React底部自定義TabBar使用React?useContext解決底部選中異常(需要點兩次才能選中的問題)示例詳解,有需要的朋友可以借鑒參考下

TabBar 的選中狀態(tài)異常

在使用 Taro 進行小程序開發(fā)時,底部 TabBar 是非常常見的頁面導航方式。然而,有時候我們可能會遇到一個問題:底部 TabBar 的選中狀態(tài)異常,需要點擊兩次才能成功選中某個標簽。本文將介紹如何使用 React 的 useContext 來解決這個問題,同時結(jié)合 Taro 的自定義 TabBar 來實現(xiàn)正常的底部導航。

所用技術

Taro,React HooKs(useContext  , createContext),@antmjs/vantui(這是UI組件)

解決方案:使用 React 的 useContext

在 Taro 中,我們可以使用 useContext 鉤子來創(chuàng)建和使用上下文。上下文能夠在組件之間共享數(shù)據(jù),這里我們將使用它來解決底部選中異常的問題。

創(chuàng)建上下文對象,管理底部TabBar選中狀態(tài)

// UserContext.js
import { createContext } from 'react';
const UserContext = createContext();
export default UserContext;

useContext 創(chuàng)建上下文

在應用的入口文件app.js中,我們將使用 useContext 創(chuàng)建上下文,并將底部 TabBar 的選中狀態(tài)放入上下文中。

// app.js
import { useState } from 'react';
import Taro, { createContext, Provider } from '@tarojs/taro';
import './app.scss';
import UserContext from './UserContext';
function App({ children }) {
  const [selectedTab, setSelectedTab] = useState(0);
  return (
    <UserContext.Provider value={{ selectedTab, setSelectedTab }}>
      {children}
    </UserContext.Provider>
  );
}
export default App;

自定義組件TabBar

現(xiàn)在,我們可以在任何組件中使用 useContext 來獲取和設置選中狀態(tài)。那么下面我們來創(chuàng)建一個自定義組件TabBar

首先在app.config.js 這樣配置 主要是tabBar中的custom要為true隱藏默認的Tabbar 也是為了后續(xù)跳轉(zhuǎn)做準備

//app.config.js 
export default defineAppConfig({
  pages: [
    "pages/index/index",
    "pages/classification/index",
    "pages/shoppingCart/index",
    "pages/user/index",
  ],
  tabBar: {
    custom: true,
    list: [
      {
        pagePath: "pages/index/index",
        text: "主頁",
      },
      {
        pagePath: "pages/classification/index",
        text: "分類",
      },
      {
        pagePath: "pages/shoppingCart/index",
        text: "購物車",
      },
      {
        pagePath: "pages/user/index",
        text: "我的",
      },
    ],
  },
  window: {
    backgroundTextStyle: "light",
    navigationBarBackgroundColor: "#fff",
    navigationBarTitleText: "WeChat",
    navigationBarTextStyle: "black",
  },
});

創(chuàng)建custom-tab-bar文件夾

然后在Src目錄下創(chuàng)建 一個文件名為 custom-tab-bar 的文件夾 然后在文件夾里創(chuàng)建一個index.js 的文件 小程序會自動獲取到此文件夾的index.js文件然后渲染到頁面上

// custom-tab-bar/index.js
import { Tabbar, TabbarItem } from '@antmjs/vantui'
import Taro from '@tarojs/taro'
import React, { useEffect, useRef, useState } from 'react'
import { useContext } from 'react';
import UserContext from '../component/UserContext';
export default function index() {
    const { selectedTab, setSelectedTab} = useContext(UserContext);
    const [tabData, setTabData] = useState({
        list: [
            {
                id: 0,
                icon: 'home-o',
                text: '首頁',
                url: 'pages/index/index',
            },
            {
                id: 1,
                icon: 'qr',
                text: '分類',
                url: 'pages/classification/indexe',
            },
            {
                id: 2,
                icon: 'shopping-cart-o',
                text: '購物車',
                url: 'pages/shoppingCart/index',
            },
            {
                id: 3,
                icon: 'manager-o',
                text: '我的',
                url: 'pages/user/index',
            },
        ]
    })
    const onChange = (e) => {
        setSelectedTab(e.detail)
        if (e.detail == 0) {
            Taro.switchTab({
                url: '/pages/index/index'
            })
        } else if (e.detail == 1) {
            Taro.switchTab({
                url: '/pages/classification/index'
            })
        } else if (e.detail == 2) {
            Taro.switchTab({
                url: '/pages/shoppingCart/index'
            })
        } else if (e.detail == 3) {
            Taro.switchTab({
                url: '/pages/user/index'
            })
        }
    }
    return (
        <Tabbar active={selectedTab} onChange={onChange}>
            {tabData.list.map(Item => {
                return <TabbarItem key={Item.id} icon={Item.icon}>
                    {Item.text}
                </TabbarItem>
            })}
        </Tabbar>
    )
}

通過使用 useContext,我們可以將選中狀態(tài)在不同的組件之間共享,從而解決底部選中異常問題。這樣,點擊底部標簽時就可以正常切換選中狀態(tài)了。

總結(jié)

使用 Taro React,我們可以使用 useContext 鉤子來解決底部 TabBar 選中異常的問題。通過創(chuàng)建上下文并共享選中狀態(tài),我們可以實現(xiàn)正常的底部導航,提供更好的用戶體驗。

希望本文能夠幫助你解決底部選中異常問題,并在 Taro 小程序開發(fā)中有更流暢的導航體驗。

以上就是Taro React自定義TabBar使用useContext解決底部選中異常的詳細內(nèi)容,更多關于React useContext底部選中的資料請關注腳本之家其它相關文章!

相關文章

  • React使用fullpage.js實現(xiàn)整屏翻頁功能

    React使用fullpage.js實現(xiàn)整屏翻頁功能

    最近筆者在完成一個移動端小項目的過程中需要實現(xiàn)整屏翻頁的效果;調(diào)研完畢之后,最終決定使用pullPage.js實現(xiàn)此功能,fullPage.js使用起來比較方便,并且官網(wǎng)上也給了在react項目中使用的demo,本文記錄了這個第三方庫的使用過程,感興趣的朋友可以參考下
    2023-11-11
  • 簡析React Native startReactApplication 方法

    簡析React Native startReactApplication 方法

    這篇文章主要介紹了React Native startReactApplication 方法簡析,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-09-09
  • React?正確使用useCallback?useMemo的方式

    React?正確使用useCallback?useMemo的方式

    這篇文章主要介紹了React?正確使用useCallback?useMemo的方式,文章圍繞主題展開詳細的內(nèi)容介紹,具有一定的參考價值,需要的朋友可以參考一下
    2022-08-08
  • react自適應布局px轉(zhuǎn)rem實現(xiàn)示例詳解

    react自適應布局px轉(zhuǎn)rem實現(xiàn)示例詳解

    這篇文章主要為大家介紹了react自適應布局px轉(zhuǎn)rem實現(xiàn)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-08-08
  • React利用props的children實現(xiàn)插槽功能

    React利用props的children實現(xiàn)插槽功能

    React中并沒有vue中的?slot?插槽概念?不過?可以通過props.children?實現(xiàn)類似功能,本文為大家整理了實現(xiàn)的具體方,需要的可以參考一下
    2023-07-07
  • react之組件通信詳解

    react之組件通信詳解

    本篇文章主要介紹了React組件通信詳解,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2021-10-10
  • GraphQL在react中的應用示例詳解

    GraphQL在react中的應用示例詳解

    這篇文章主要為大家介紹了GraphQL在react中的應用示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-10-10
  • 解決React報錯Cannot assign to 'current' because it is a read-only property

    解決React報錯Cannot assign to 'current'

    這篇文章主要為大家介紹了React報錯Cannot assign to 'current' because it is a read-only property的解決方法,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-12-12
  • react性能優(yōu)化達到最大化的方法 immutable.js使用的必要性

    react性能優(yōu)化達到最大化的方法 immutable.js使用的必要性

    這篇文章主要為大家詳細介紹了react性能優(yōu)化達到最大化的方法,一步一步優(yōu)化react性能的過程,告訴大家使用immutable.js的必要性,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-03-03
  • webpack入門+react環(huán)境配置

    webpack入門+react環(huán)境配置

    webpack是一個前端資源模塊化管理和打包工具,說白了就是方便我們管理自己的常用的一些代碼,比如你開發(fā)中用到sass以及jade同時用到es6,開發(fā)時你不可能改動某個地方就挨個命令去轉(zhuǎn)換再到瀏覽器去看效果,那樣效率是非常低的。所以webpack幫我們省去了那些多余的步驟。
    2017-02-02

最新評論