uniApp跨页面通讯$on、$emit、$once、$off使用场景及技巧

大部分场景实际上利用once、emit、$off配合使用即可,直接上代码

在页面B中,离开时必须要销毁$once(xxx),因为在B页面,点击拍照才会触发$emit(xxx),如果通过滑动或点击头部返回页面A,once(xxx)将会和下一次emit(xxx)调用时,一起触发。
所以调用销毁方法$off(xxx)的实际很重要,onUnmounted配合nextTick使用,刚好不会影响上个页面A正常通过takePhoto 触发的事件

页面A

javascript 复制代码
<template>
  <button @click="fn1">按钮1</button>
  <button @click="fn2">按钮2</button>
</template>

<script setup lang='ts'>
import { reactive, toRefs, onBeforeMount, onMounted } from 'vue'
const state = reactive({
  list1: [] as string[],
  list2: [] as string[]
})

const fn1 = () => {
  uni.navigateTo({ url: '页面B'})
  uni.$once('xxx', () => {
    // 监听后的逻辑
  })
}

const fn2 = () => {
  uni.navigateTo({ url: '页面B'})
  uni.$once('xxx', () => {
    // 监听后的逻辑
  })
}

</script>

<style lang="scss" scoped>

</style>

页面B

javascript 复制代码
<template>
  <my-header>点击可返回</my-header>
  <camera device-position="back" flash="off" style="width: 100%; height: 300px;"></camera>
  <button type="primary" @click="takePhoto">拍照</button>
</template>

<script setup lang='ts'>
import { reactive, toRefs, nextTick, onUnmounted } from 'vue'
const takePhoto = () => {
  const ctx = uni.createCameraContext();
  ctx.takePhoto({
    quality: 'high',
    success: (res) => {
      uni.$emit('xxx', res)
    }
  })
}

onUnmounted(() => {
  nextTick(() => {
    uni.$off('xxx')
    uni.navigateBack()
  })
})
</script>

<style lang="scss" scoped></style>
相关推荐
Jiaberrr4 分钟前
前端实战:使用JS和Canvas实现运算图形验证码(uniapp、微信小程序同样可用)
前端·javascript·vue.js·微信小程序·uni-app
工业互联网专业2 小时前
毕业设计选题:基于springboot+vue+uniapp的驾校报名小程序
vue.js·spring boot·小程序·uni-app·毕业设计·源码·课程设计
&白帝&9 小时前
uniapp中使用picker-view选择时间
前端·uni-app
fakaifa10 小时前
八戒农场小程序V2最新源码
小程序·uni-app·php·生活·开源软件
平凡シンプル14 小时前
安卓 uniapp跨端开发
android·uni-app
艾小逗16 小时前
uniapp快速入门教程,内容来源于官方文档,仅仅记录快速入门需要了解到的知识点
小程序·uni-app·app·es6
鸭子嘎鹅子呱1 天前
uniapp使用高德地图设置marker标记点,后续根据接口数据改变某个marker标记点,动态更新
uni-app·map·高德地图
计算机源码社1 天前
分享一个基于微信小程序的居家养老服务小程序 养老服务预约安卓app uniapp(源码、调试、LW、开题、PPT)
android·微信小程序·uni-app·毕业设计项目·毕业设计源码·计算机课程设计·计算机毕业设计开题
Angus-zoe2 天前
uniapp+vue+微信小程序实现侧边导航
vue.js·微信小程序·uni-app
Pluto & Ethereal2 天前
uni-app尺寸单位、flex布局于背景图片
uni-app