uniapp 跨页面传值及跨页面方法调用

uniapp 跨页面传值及跨页面方法调用

1、跨页面传值

使用全局方法监听uni.$emituni.$onuni.$off 发布、监听、移除

js 复制代码
methods: {
	addFun(){
		let data = [1]
		uni.navigateBack({ // 返回上一页
          delta: 1
        })
		uni.$emit('successFun',{data}) // 传值
	}
}

监听页

js 复制代码
onLoad() {
    uni.$on('successFun', (e => {
        // ...do something
    }))
},
onUnload() {
    // 移除监听
    uni.$off('successFun');
},
2、跨页面方法调用

场景:当前页面数据提交后需要更新上一页的表单,调用当前页的上一页的某个方法

js 复制代码
methods: {
	addFun(){
		let pages = getCurrentPages() // 获取当前页面栈的实例,以数组形式按栈的顺序给出,第一个元素为首页,最后一个元素为当前页面。
        let prevPage = pages[pages.length - 2] //上一页页面实例
		let data = [1]
		uni.navigateBack({ // 返回上一页
          delta: 1,
          success: () => {
        	prevPage.$vm.fartherFun(data) // 调用上一页的方法,传参
		  }
        })
	}
}
相关推荐
是烟花哈40 分钟前
【前端】React框架学习
前端·学习·react.js
qq4356947011 小时前
JavaWeb08
前端
2401_878454532 小时前
html和css的复习(1)
前端·css·html
@PHARAOH3 小时前
WHAT - git worktree 概念
前端·git
IT_陈寒3 小时前
我竟然被JavaScript的隐式类型转换坑了三天!
前端·人工智能·后端
我亚索贼六丶3 小时前
二十六. AI基础概念之如何更好的使用AI
前端
小码哥_常3 小时前
安卓启动页Logo适配秘籍:告别“奇形怪状”的展示
前端
我亚索贼六丶3 小时前
二十五.Electron 初体验与进阶
前端
当时只道寻常3 小时前
像使用 Redis 一样操作 LocalStorage
前端·前端工程化
RONIN3 小时前
UI组件库elementplus
前端