Maison >interface Web >uni-app >Introduction détaillée à la méthode de saut de page UniApp et de transfert de valeur

Introduction détaillée à la méthode de saut de page UniApp et de transfert de valeur

PHPz
PHPzoriginal
2023-04-14 19:39:034575parcourir

Ces dernières années, avec le développement de la technologie Internet mobile et la popularité des appareils mobiles, le développement d'applications est devenu un moyen à la mode et efficace de développer ses activités. En tant qu'outil de développement multiplateforme, UniApp est très pratique et efficace dans le processus de développement d'applications. Cependant, nous devons utiliser certaines méthodes spécifiques lors du développement de sauts de page et de transferts de paramètres impliqués dans le développement d'applications UniApp. Dans cet article, nous présenterons en détail la méthode de saut de page UniApp et de transfert de valeur.

1. Utiliser l'URL pour transmettre les paramètres

La méthode de saut de page et de transmission de valeurs dans UniApp consiste à utiliser l'URL pour transmettre les paramètres, ce qui est similaire à la transmission d'URL utilisée dans le développement Web général. Nous pouvons ajouter des paramètres à l'URL, puis obtenir ces paramètres via l'attribut de requête de l'objet composant dans la page après le saut.

Supposons que nous ayons deux interfaces A et B. Nous devons passer à la page B de la page A et transmettre certains paramètres à la page B. Nous pouvons implémenter le saut de page et le transfert de paramètres via le code suivant :

// 在A页面中,点击按钮跳转到B页面,并传递参数
<template>
  <view>
    <button @click="navigateToB">跳转到B页面</button>
  </view>
</template>

<script>
  export default {
    methods: {
      navigateToB() {
        uni.navigateTo({
          url: '/pages/B/B?id=123&name=UniApp',
          success: function(res) {
            console.log('跳转到B页面成功')
          }
        })
      }
    }
  }
</script>

Dans le code ci-dessus, nous implémentons le saut de page vers la page B via la méthode uni.navigateTo, et ajoutons l'identifiant et le nom du paramètre sous forme de clé-valeur. dans l'URL. Dans la page B, nous pouvons obtenir ces paramètres via la méthode this.$route.query, comme indiqué ci-dessous : this.$route.query方法获取这些参数,如下所示:

// 在B页面中,获取A页面传递的参数
<script>
  export default {
    mounted() {
      console.log(this.$route.query)
    }
  }
</script>

通过这种方式,我们可以比较方便地实现页面跳转和参数传递,但是它需要手动拼接URL,容易出错,且参数传递只适用于字符串类型。

2.使用uni-app提供的API

除了使用URL传参的方式,UniApp还提供了一些API来实现页面跳转和参数传递。具体实现方式如下:

// 在A页面中,点击按钮跳转到B页面,并传递参数
<template>
  <view>
    <button @click="navigateToB">跳转到B页面</button>
  </view>
</template>

<script>
  export default {
    methods: {
      navigateToB() {
        uni.navigateTo({
          url: '/pages/B/B',
          eventChannel: {
            emit: 'acceptDataFromA',
            data: {
              id: 123,
              name: 'UniApp'
            }
          },
          success: function(res) {
            console.log('跳转到B页面成功')
          }
        })
      }
    }
  }
</script>

在上述代码中,我们使用了eventChannel来实现页面之间的参数传递。在页面A跳转到页面B时,我们先创建一个事件通道eventChannel,然后将需要传递的参数添加到eventChannel.data对象中。在跳转成功时,我们将这个事件通道的名称acceptDataFromA和数据eventChannel.data

// 在B页面中,接受A页面传递的参数
<script>
  export default {
    created() {
      const eventChannel = this.getOpenerEventChannel()
      eventChannel.on('acceptDataFromA', (data) => {
        console.log(data)
      })
    }
  }
</script>
De cette façon, nous pouvons plus facilement implémenter des sauts de page et des transferts de paramètres, mais cela nécessite un épissage manuel des URL, ce qui est sujet aux erreurs, et la transmission de paramètres ne s'applique qu'aux types de chaînes.

2. Utilisez l'API fournie par uni-app

En plus d'utiliser les paramètres d'URL, UniApp fournit également des API pour implémenter les sauts de page et le transfert de paramètres. L'implémentation spécifique est la suivante :

rrreee

Dans le code ci-dessus, nous utilisons eventChannel pour implémenter le transfert de paramètres entre les pages. Lorsque la page A passe à la page B, nous créons d'abord un canal d'événement eventChannel, puis ajoutons les paramètres qui doivent être transmis à l'objet eventChannel.data. Lorsque le saut est réussi, nous transmettons le nom de ce canal d'événements acceptDataFromA et les données eventChannel.data à la page B. Dans la page B, nous pouvons recevoir ces paramètres via le code suivant :

rrreee

De cette façon, nous pouvons réaliser des sauts de page et des transferts de paramètres sans épisser manuellement les URL, et prendre en charge plusieurs types différents de transfert de paramètres. 🎜🎜Résumé🎜🎜Dans le développement d'applications UniApp, le saut de page et le passage de paramètres sont un lien relativement important. En explorant le passage des paramètres d'URL et l'utilisation de l'API, nous pouvons constater qu'UniApp fournit une variété de méthodes pour implémenter les sauts de page et le passage de paramètres. Chacune de ces méthodes a ses propres avantages, et les développeurs peuvent choisir la méthode appropriée en fonction des besoins réels. 🎜🎜Il est recommandé aux développeurs d'explorer et d'essayer activement différentes méthodes lors du développement d'applications UniApp, des sauts de page maître et des transferts de paramètres, et de les appliquer de manière flexible à leurs propres scénarios commerciaux. De cette façon, vous pouvez non seulement améliorer l'efficacité du développement et l'expérience utilisateur de votre application, mais également vous apporter plus de valeur. 🎜

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:
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