uniApp页面通讯

Uniapp 是一款基于 Vue.js 开发的框架,它可以用来开发多端应用,包括微信小程序、H5、APP 等。在 Uniapp 中,页面通讯分为三种方式:事件总线、Vuex 和 uni.$emit。

  1. 事件总线(EventBus):事件总线是一种非常方便的通讯方式,它可以在多个组件之间传递数据。事件总线在 Vue 中是通过 $emit 和 $on 方法进行绑定和监听的。在 Uniapp 中,可以使用 uni.$emit 和 uni.$on 方法来实现事件总线。

  2. Vuex:Vuex 是一种专门为 Vue.js 开发的状态管理库,它可以将需要共享的数据集中存储,以便于在多个组件中共享。在 Uniapp 中,可以使用 Vuex 来进行页面通讯。

  3. uni.$emit:与事件总线类似,uni.$emit 也可以用来实现页面之间的通讯。它也是通过 $emit 和 $on 方法进行绑定和监听的,不过它是全局对象 uni 上的方法,可以在任何页面中调用。


以下是一个简单的示例,演示如何使用 Uniapp 实现页面之间的通讯:

在页面 A 中,我们定义了一个事件,并在事件中传递了一个参数:

// A 页面
export default {
  methods: {
    handleClick() {
      const data = { name: 'Tom', age: 20 }
      uni.$emit('myEvent', data)
    }
  }
}

在页面 B 中,我们通过监听事件的方式来获取页面 A 传递过来的参数:

// B 页面
export default {
  mounted() {
    uni.$on('myEvent', data => {
      console.log(data) // => { name: 'Tom', age: 20 }
    })
  }
}

这样,当我们在页面 A 中点击按钮触发事件时,页面 B 就会接收到传递的参数并进行处理。需要注意的是,在使用事件总线时,需要在组件销毁时移除监听,避免内存泄漏:

destroyed() {
  uni.$off('myEvent')
}

以上是一个简单的示例,演示了 Uniapp 中使用事件总线实现页面通讯的方法。实际应用中,我们可能需要使用 Vuex 或其他方式来进行更复杂的页面通讯需求。

你可能感兴趣的:(uniapp,微信小程序,uni-app,前端)