当前位置: 首页 > article >正文

uniapp 如何修改 返回按钮(左上角+物理按钮+侧滑)触发的返回事件

背景:

使用uniapp 开发安卓app,在用户编辑后直接返回时,使用弹窗提醒用户:还没有保存,是否保存?

方案

1. 使用自定义返回事件

//返回
back() {
// 业务逻辑,弹窗提醒
uni.showModal({
	title: '内容尚未保存,是否保存?',
	success: function (res) {
		if (res.confirm) {
			saveFun()
		} else if (res.cancel) {
			console.log('用户点击取消');
			// 然后返回
			uni.navigateBack()
		}
	}
})

},

结果:点击自定义的按钮没有问题,但是使用原生按钮返回或者是侧滑返回依旧不执行自定义逻辑

2. 使用onBackPress生命周期函数

onBackPress((option) =>{
	if(option.from === 'backbutton'){
		uni.showModal({
			title: '内容尚未保存,是否保存?',
			success: function (res) {
				if (res.confirm) {
					saveFun()
				} else if (res.cancel) {
					console.log('用户点击取消');
					// 然后返回
					uni.navigateBack()
				}
			}
		})
	
	}
	return true;
})

结果:虽然会提醒,但是无法阻止返回事件,在用户还没有点击保存的时候,它就已经返回到上一个页面了,这个也不行

3. 我测试成功的方案:使用uni拦截器

  • 添加拦截器
onShow(() =>{
	const {diaryContext,setDiaryContext} = useEditStore();
	setDiaryContext(diaryRef.value)
	uni.addInterceptor('navigateBack', {
	invoke(args) {
			// 判断是不是返回按钮触发的返回事件
		  if(args?.from === 'backbutton'){
		  		// 必须使用状态管理获取组件实例,拦截器中不能直接拿到组件的实例
			  backFun(diaryContext);
			  return false; // 阻止返回
		  }else{
			  return true; // 允许返回
		  }
	}
	})
})
  • 卸载拦截器,拦截器需要记得卸载
onHide(() =>{
	uni.removeInterceptor('navigateBack')
})

结果:使用拦截器就可以将原生返回事件进行自定义修改,包括静止原生返回事件
ps: 仅仅在安卓app 中测试有效,其他的没有测试


http://www.kler.cn/a/379735.html

相关文章:

  • 极品飞车6里的赛道简介
  • 【数据结构高阶】B-树
  • vue3+vite图片动态地址问题 + nginx配置
  • YangQG 面试题汇总
  • 【Apache Paimon】-- 13 -- 利用 paimon-flink-action 同步 mysql 表数据
  • spark汇总
  • 【Docker系列】指定系统平台拉取 openjdk:8 镜像
  • 结构体对齐,位段
  • 支持 Mermaid 语言预览,用通义灵码画流程图
  • centos7 kafka高可用集群安装及测试
  • 【Git】SSH密钥
  • json和pb的比较
  • 第八篇: 通过使用Google BigQuery进行数据批量和自动化处理
  • 【MATLAB源码-第204期】基于matlab的语音降噪算法对比仿真,谱减法、维纳滤波法、自适应滤波法;参数可调。
  • unity游戏开发之--人物打怪爆材料--拾进背包的实现思路
  • 如何实现PHP安全过滤
  • AI赋能财务管理,AI技术助力企业自动化处理财务数据
  • .NET 开发人员实用NuGet 包,加快开发速度
  • 【深度学习】多分类任务评估指标sklearn和torchmetrics对比
  • 策略模式(C++)三分钟读懂
  • Naive UI 选择器 Select 的:render-option怎么使用(Vue3 + TS)(鼠标悬停该条数据的时候展示全部内容)
  • Java项目实战II基于Java+Spring Boot+MySQL的编程训练系统(源码+数据库+文档)
  • Windows密码的网络认证---基于挑战响应认证的NTLM协议
  • asynDriver-6-端口驱动
  • MQTT自动发送消息工具(自动化测试MQTT)
  • R语言贝叶斯:INLA下的贝叶斯回归、生存分析、随机游走、广义可加模型、极端数据的贝叶斯分析