Maison interface Web uni-app Comment uniapp implémente-t-il le préchargement de plusieurs autres pages TabBar ?

Comment uniapp implémente-t-il le préchargement de plusieurs autres pages TabBar ?

Apr 20, 2023 pm 03:08 PM

Ces dernières années, les applications mobiles sont devenues un élément essentiel de la vie des gens. Avec le développement des applications mobiles, de plus en plus d'applications adoptent le design TabBar, notamment dans les applications, TabBar est devenu la principale méthode de navigation pour de nombreuses applications. Parmi eux, le framework Uniapp peut être considéré comme le framework de développement multiplateforme léger le plus populaire à l'heure actuelle. Cependant, de nombreux développeurs rencontreront un problème courant lorsqu'ils utiliseront Uniapp pour développer des applications TabBar : Comment précharger plusieurs autres pages TabBar ?

Pendant le processus de développement d'Uniapp, TabBar peut être créé en configurant la page dans pages.json. Par exemple, définissez la page suivante dans pages.json :

{
  "pages": [
    {
      "path": "pages/index/index",
      "style": {}
    },
    {
      "path": "pages/category/category",
      "style": {}
    },
    {
      "path": "pages/cart/cart",
      "style": {}
    },
    {
      "path": "pages/me/me",
      "style": {}
    }
  ],
  "tabBar": {
    "color": "#999999",
    "selectedColor": "#000000",
    "backgroundColor": "#ffffff",
    "borderStyle": "black",
    "list": [
      {
        "pagePath": "pages/index/index",
        "text": "首页",
        "iconPath": "static/tabbar/home.png",
        "selectedIconPath": "static/tabbar/home_active.png"
      },
      {
        "pagePath": "pages/category/category",
        "text": "分类",
        "iconPath": "static/tabbar/category.png",
        "selectedIconPath": "static/tabbar/category_active.png"
      },
      {
        "pagePath": "pages/cart/cart",
        "text": "购物车",
        "iconPath": "static/tabbar/cart.png",
        "selectedIconPath": "static/tabbar/cart_active.png"
      },
      {
        "pagePath": "pages/me/me",
        "text": "我的",
        "iconPath": "static/tabbar/me.png",
        "selectedIconPath": "static/tabbar/me_active.png"
      }
    ]
  }
}
Copier après la connexion

Dans ce fichier de configuration, nous définissons 4 pages et créons une TabBar. Parmi eux, chaque page correspond à un élément de menu dans la TabBar. Lorsque nous cliquons sur différents éléments du menu, Uniapp passera à la page correspondante.

Cependant, dans ce processus, Uniapp ne préchargera la page actuelle que lors de son chargement, et ne préchargera pas les autres pages. Par conséquent, lorsque nous passons d’une page TabBar à une autre, la page peut se charger lentement, affectant l’expérience utilisateur. Alors, comment résoudre ce problème ?

Méthodes pour précharger d'autres pages TabBar :

Dans Uniapp, nous pouvons précharger d'autres pages TabBar en utilisant uni.request. Cette méthode peut obtenir les données de la page spécifiée en envoyant une requête GET et mettre les données en cache. Lorsque nous cliquons sur l'élément de menu TabBar correspondant, le système vérifiera d'abord si les données existent dans le cache, si elles existent dans le cache, il affichera les données directement. Si elles n'existent pas, il enverra à nouveau la demande et le mettra en cache. les données.

Dans pages.json, ajoutez un champ de préchargement pour définir l'URL de la page qui doit être préchargée :

{
  "pages": [
    {
      "path": "pages/index/index",
      "style": {}
    },
    {
      "path": "pages/category/category",
      "style": {},
      "preload": true
    },
    {
      "path": "pages/cart/cart",
      "style": {},
      "preload": true
    },
    {
      "path": "pages/me/me",
      "style": {},
      "preload": true
    }
  ],
  "tabBar": {
    ...
  }
}
Copier après la connexion

Dans le fichier de configuration ci-dessus, nous avons ajouté l'attribut de préchargement pour les pages de catégorie, de panier et moi et l'avons ajouté défini sur true . Cela signifie que lorsque la page d'accueil de l'application est chargée, Uniapp chargera automatiquement ces pages et les mettra en cache localement.

Ensuite, nous appelons uni.request dans App.vue pour implémenter la fonction de préchargement de page :

<template>
  <div class="app">
    <uni-tab-bar :list="tabBar.list" :color="tabBar.color" :selected-color="tabBar.selectedColor" :background-color="tabBar.backgroundColor" :border-style="tabBar.borderStyle" @change="onTabChange"></uni-tab-bar>
  </div>
</template>

<script>
export default {
  data() {
    return {
      tabBar: uni.getStorageSync('tabBar') || {
        color: '#999999',
        selectedColor: '#000000',
        backgroundColor: '#ffffff',
        borderStyle: 'black',
        list: []
      },
      currentTab: 0
    }
  },
  onLoad() {
    uni.request({
      url: '/pages/me/me',
      method: 'GET',
      success: (res) => {
        uni.setStorageSync('/pages/me/me', res.data)
      }
    })
    uni.request({
      url: '/pages/cart/cart',
      method: 'GET',
      success: (res) => {
        uni.setStorageSync('/pages/cart/cart', res.data)
      }
    })
    uni.request({
      url: '/pages/category/category',
      method: 'GET',
      success: (res) => {
        uni.setStorageSync('/pages/category/category', res.data)
      }
    })
  },
  methods: {
    onTabChange(e) {
      const url = this.tabBar.list[e.index].pagePath
      this.currentTab = e.index
      uni.setStorageSync('currentTab', e.index)
      let pageData = uni.getStorageSync(url)
      if (!pageData) {
        uni.showLoading()
        // 发送请求获取数据
        uni.request({
          url: url,
          method: 'GET',
          success: (res) => {
            uni.hideLoading()
            pageData = res.data
            // 将获取的数据缓存到本地
            uni.setStorageSync(url, pageData)
          }
        })
      }
    }
  }
}
</script>
Copier après la connexion

Dans le code ci-dessus, nous utilisons uni.request dans la méthode onLoad d'App.vue pour obtenir la catégorie, le panier et les données de ma page est mise en cache localement.

Lorsque vous cliquez sur un élément de menu TabBar, nous obtiendrons l'URL de la page correspondante en fonction de l'index de l'élément de menu et vérifierons si la page a été mise en cache localement. Si elle est mise en cache, les données sont lues directement à partir du cache et la page est rendue ; si elle n'est pas mise en cache, une requête GET est envoyée pour obtenir les données et mises en cache localement, puis la page est rendue.

Ce qui précède explique comment précharger d'autres pages TabBar dans Uniapp. En préchargeant les pages, nous pouvons afficher rapidement la page correspondante lorsque l'utilisateur clique sur l'élément de menu TabBar pour changer de page, améliorant ainsi l'expérience utilisateur.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌
Will R.E.P.O. Vous avez un jeu croisé?
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Comment utiliser des préprocesseurs (Sass, moins) avec Uni-App? Comment utiliser des préprocesseurs (Sass, moins) avec Uni-App? Mar 18, 2025 pm 12:20 PM

L'article discute de l'utilisation de SASS et moins de préprocesseurs dans UNI-APP, de la configuration de détail, des avantages sociaux et de la double utilisation. L'accent principal est sur la configuration et les avantages. [159 caractères]

Comment utiliser l'API d'animation Uni-App? Comment utiliser l'API d'animation Uni-App? Mar 18, 2025 pm 12:21 PM

L'article explique comment utiliser l'API d'animation d'Uni-App, détaillant les étapes pour créer et appliquer des animations, des fonctions clés et des méthodes pour combiner et contrôler la synchronisation de l'animation. Count de chargement: 159

Quels sont les différents types de tests que vous pouvez effectuer dans une application UNIAPP? Quels sont les différents types de tests que vous pouvez effectuer dans une application UNIAPP? Mar 27, 2025 pm 04:59 PM

L'article traite de divers types de tests pour les applications UNIAPP, y compris l'unité, l'intégration, les tests fonctionnels, UI / UX, les performances, la plate-forme multiplateforme et la sécurité. Il couvre également une compatibilité multiplateforme et recommande des outils comme JES

Quels outils de débogage sont disponibles pour le développement UNIAPP? Quels outils de débogage sont disponibles pour le développement UNIAPP? Mar 27, 2025 pm 05:05 PM

L'article traite des outils de débogage et des meilleures pratiques pour le développement de l'UNIAPP, en se concentrant sur des outils comme HBuilderx, WeChat Developer Tools et Chrome Devtools.

Comment utiliser l'API de stockage Uni-App (Uni.SetStorage, Uni.getStorage)? Comment utiliser l'API de stockage Uni-App (Uni.SetStorage, Uni.getStorage)? Mar 18, 2025 pm 12:22 PM

L'article explique comment utiliser les API de stockage Uni-App (Uni.SetStorage, Uni.getStorage) pour la gestion des données locales, discute des meilleures pratiques, dépannage et met en évidence les limitations et les considérations pour une utilisation efficace.

Comment pouvez-vous réduire la taille de votre package d'application UNIAPP? Comment pouvez-vous réduire la taille de votre package d'application UNIAPP? Mar 27, 2025 pm 04:45 PM

L'article traite des stratégies pour réduire la taille du package UNIAPP, en se concentrant sur l'optimisation du code, la gestion des ressources et les techniques comme le fractionnement du code et le chargement paresseux.

Comment utiliser l'API Uni-App pour accéder aux fonctionnalités des appareils (appareil photo, géolocalisation, etc.)? Comment utiliser l'API Uni-App pour accéder aux fonctionnalités des appareils (appareil photo, géolocalisation, etc.)? Mar 18, 2025 pm 12:06 PM

L'article discute de l'utilisation des API de l'Uni-App pour accéder aux fonctionnalités des appareils comme la caméra et la géolocalisation, y compris les paramètres d'autorisation et la gestion des erreurs. Compte de chargement: 158

Comment valider la saisie de l'utilisateur dans Uni-App? Comment valider la saisie de l'utilisateur dans Uni-App? Mar 18, 2025 pm 12:17 PM

L'article discute de la validation de la saisie de l'utilisateur dans Uni-App à l'aide de la liaison JavaScript et des données, mettant l'accent sur la validation du client et du côté serveur pour l'intégrité des données. Des plugins comme Uni-validate sont recommandés pour la validation du formulaire.

See all articles