uniapp开发小程序 二级页面触发一级页面的事件或者更新数据以及页面跳转传递传参、转发功能

二级页面触发一级页面:

二级页面代码:

uni.navigateBack({
			delta: 1,
			success() {
				const pages = getCurrentPages();
				const targetPage = pages[0];
				targetPage.$vm.addJournalState=true
	}
})

有人部分博客获取上一页信息是通过这样获取的:var targetPage = pages[pages.length - 2],我这样获取显示undefined,大家可以把ages打印一下,看看内容,然后自行选择

注解:

getCurrentPages()方法来获取当前页面栈

$vm是指Vue组件实例

一级页面代码:

		onShow() {
			setTimeout(() => {
				if (this.addJournalState) {
                    // 重新获取数据
					this.upJournal()
					this.addJournalState = false
				}
			}, 100)
		}

每次页面切换就会判断一下,如何是指定二级页面返回过来,会将状态设置为ture,就会执行代码重新获取数据,其他则不会

注解:

使用setTimeout的原因是因为确认一级页面addJournalState状态已经被修改

页面跳转传递传参

跳转页:

uni.navigateTo({
			url: '/pages/material/purchaseDetails?data=' + encodeURIComponent(JSON
							.stringify(argumentAll))
})

接受页:

onLoad(options) {
			// 获取页面传递的对象参数
			const data = JSON.parse(decodeURIComponent(options.data));
			this.dataObj = data
}

注解:

encodeURIComponent 是 JavaScript 中的一个函数,用于对 URI(统一资源标识符)中的特殊字符进行编码。它将指定的字符串作为参数,并返回一个新的字符串,其中包含了经过编码的特殊字符

decodeURIComponent 是 JavaScript 中的一个函数,用于解码经过 encodeURIComponent 编码的 URI(统一资源标识符)字符串。它将编码后的字符串作为参数,并返回一个新的字符串 

转发功能 

效果图:

转发功能: 

<template>
  <view class="container">
    <button class="share-btn" open-type="share">转发</button>
  </view>
</template>

<script>
export default {
  data() {
    return {};
  },
  onShareAppMessage() {
    return {
      title: '这是分享的标题',
      path: '/pages/index/index',
      imageUrl: '/static/share.jpg'
    }
  },
};
</script>

<style scoped>
.container {
  display: flex;
  justify-content: center;
  align-items: center;
  height: 100vh;
}

.share-btn {
  width: 200rpx;
  height: 80rpx;
  background-color: #007aff;
  color: #ffffff;
  border-radius: 40rpx;
  font-size: 32rpx;
  line-height: 80rpx;
  text-align: center;
}
</style>

注解:

open-type="share"表示将该按钮设置为小程序默认的分享按钮。

onShareAppMessage()是小程序提供的一个生命周期函数,当用户点击分享按钮时会自动调用该函数,并且根据该函数返回的分享内容进行分享

title属性,表示小程序分享的标题,这里设置为“这是分享的标题”。

path属性,表示小程序分享的路径,这里设置为小程序首页的路径/pages/index/index

imageUrl属性,表示小程序分享时的封面图,这里设置为静态资源目录下的一张图片。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

来自湖南的阿晨

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值