当前位置:   article > 正文

uniapp之vue3.2 微信小程序开发:路由跳转传参,页面通讯:修改上一页面的数据,监听页面回退传递的数据_uniapp vue3 更改 上一个页面参数

uniapp vue3 更改 上一个页面参数

场景:最近做的小程序电商模块在确认订单的时候可以修改地址,点击默认地址会跳到地址管理去,点击地址管理中的地址后页面回退把选中的地址传回来,点击默认地址跳到地址管理修改默认地址后回退到确认订单要显示新的默认地址

1.页面跳转  --传递参数允许在地址管理点击地址回退传递参数

  1. const addressFn = () => {
  2. uni.navigateTo({
  3. url: "/pages/my/address/index?isBackAddress=true",
  4. })
  5. }

接收页面跳转传递的参数

  1. import { onLoad, onShow } from '@dcloudio/uni-app';
  2. import { ref } from "vue";
  3. onLoad((options: any) => {
  4. isBackAddress.value = options.isBackAddress
  5. });
  6. const isBackAddress = ref<boolean>(false)

2.点击返回  --点击列表item返回上一页面通过页面通讯 传递点击的item给上一页面

  1. const adddressBackFn = (data: addressListType) => {
  2. if (!isBackAddress.value) return //点击是否返回
  3. let pages = getCurrentPages(); // 当前页面
  4. let prevPage = pages[pages.length - 2]; // 上一页
  5. prevPage.$vm.refreshDefaultAddress = true //修改上一页面的值
  6. setTimeout(() => {
  7. uni.$emit('UpAddressData', data)//触发自定义事件,附加参数都会传给监听器回调函数
  8. }, 300)
  9. uni.navigateBack({//返回上一页面
  10. delta: 1
  11. })
  12. }

3.点击左上角返回按钮监听返回--自定义导航栏

  1. // ui
  2. <view class="box-bg">
  3. <uni-nav-bar :border="false" backgroundColor="#F4F5F7" left-icon="left" title="地址管理" @clickLeft="backFn" />
  4. </view>
  5. //js 获取获取胶囊按钮的高度
  6. const nav_topHeight = ref<string>(uni.getStorageSync('MenuButton').height + 'rpx')
  7. const backFn = () => {
  8. let pages = getCurrentPages(); // 当前页面
  9. let prevPage = pages[pages.length - 2]; // 上一页
  10. if (prevPage.$vm.refreshDefaultAddress) {
  11. prevPage.$vm.refreshDefaultAddress = false
  12. }
  13. uni.navigateBack({//返回上一页面
  14. delta: 1
  15. })
  16. }
  17. //css
  18. .box-bg {
  19. margin-top: v-bind(nav_topHeight);
  20. }

4.判断值是否被修改,如果被修改那么就用监听修改后的值

  1. onShow(async () => {
  2. // 判断是否被修改
  3. if (refreshDefaultAddress.value) {
  4. uni.$off('UpAddressData')//先销毁一次监听,再进行新的一次监听,否则会出现重复监听的现象
  5. //监听修改后传递过来的数据
  6. uni.$once('UpAddressData', (data => {
  7. defaultAddress.value = data
  8. }))
  9. } else {
  10. // 请求默认地址
  11. const res = await RequesApi.AddRessApi({
  12. "DoType": "5",
  13. "LanguageType": "zh_Hans_CN"
  14. })
  15. defaultAddress.value = res.data.Data[0]
  16. }
  17. })
  18. const refreshDefaultAddress = ref<boolean>(false)
  19. const defaultAddress = ref<addressListType>() //地址数据
  20. defineExpose({ refreshDefaultAddress }) //把数据暴露出去

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/我家自动化/article/detail/123822?site
推荐阅读
相关标签
  

闽ICP备14008679号